AES加密 小灰灰 2022-03-09 14:46 288阅读 0赞 import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import javax.crypto.BadPaddingException; import javax.crypto.Cipher; import javax.crypto.IllegalBlockSizeException; import javax.crypto.KeyGenerator; import javax.crypto.NoSuchPaddingException; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; public class AESCryptoSecurity { public AESCryptoSecurity() { } public static byte[] encrypt(byte[] content, String keyWord) { try { KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG"); secureRandom.setSeed(keyWord.getBytes()); kgen.init(128, secureRandom); SecretKey secretKey = kgen.generateKey(); byte[] enCodeFormat = secretKey.getEncoded(); SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(1, key); byte[] result = cipher.doFinal(content); return result; } catch (NoSuchAlgorithmException var9) { var9.printStackTrace(); } catch (NoSuchPaddingException var10) { var10.printStackTrace(); } catch (InvalidKeyException var11) { var11.printStackTrace(); } catch (IllegalBlockSizeException var12) { var12.printStackTrace(); } catch (BadPaddingException var13) { var13.printStackTrace(); } return null; } public static String encrypt(String content, String password) { String encryptStr = null; try { encryptStr = parseByte2HexStr(encrypt(content.getBytes("utf-8"), password)); } catch (UnsupportedEncodingException var4) { var4.printStackTrace(); } return encryptStr; } public static byte[] decrypt(byte[] content, String keyWord) { try { KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG"); secureRandom.setSeed(keyWord.getBytes()); kgen.init(128, secureRandom); SecretKey secretKey = kgen.generateKey(); byte[] enCodeFormat = secretKey.getEncoded(); SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(2, key); byte[] result = cipher.doFinal(content); return result; } catch (NoSuchAlgorithmException var9) { var9.printStackTrace(); } catch (NoSuchPaddingException var10) { var10.printStackTrace(); } catch (InvalidKeyException var11) { var11.printStackTrace(); } catch (IllegalBlockSizeException var12) { var12.printStackTrace(); } catch (BadPaddingException var13) { var13.printStackTrace(); } return null; } public static String decrypt(String content, String keyWord) { byte[] btVals = decrypt(parseHexStr2Byte(content), keyWord); return btVals != null ? new String(btVals) : null; } public static String parseByte2HexStr(byte[] buf) { StringBuffer sb = new StringBuffer(); byte[] arr$ = buf; int len$ = buf.length; for(int i$ = 0; i$ < len$; ++i$) { byte element = arr$[i$]; String hex = Integer.toHexString(element & 255); if (hex.length() == 1) { hex = '0' + hex; } sb.append(hex.toUpperCase()); } return sb.toString(); } public static byte[] parseHexStr2Byte(String hexStr) { if (hexStr.length() < 1) { return null; } else { byte[] result = new byte[hexStr.length() / 2]; for(int i = 0; i < hexStr.length() / 2; ++i) { int high = Integer.parseInt(hexStr.substring(i * 2, i * 2 + 1), 16); int low = Integer.parseInt(hexStr.substring(i * 2 + 1, i * 2 + 2), 16); result[i] = (byte)(high * 16 + low); } return result; } } public static void main(String[] args) { String encryptStr = encrypt("7758521", "ccqwd551bcvvccqqbrrwqfdb8cdcb2dc"); System.out.println(encryptStr.toLowerCase()); System.out.println(encryptStr.length()); String result = decrypt(encryptStr, "ccqwd551bcvvccqqbrrwqfdb8cdcb2dc"); System.out.println(result); } }
相关 AES加密 一、AES是什么 AES高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府 我就是我/ 2023年10月03日 17:58/ 0 赞/ 38 阅读
相关 AES 加密 util.encryption = function (params) \{ let \{ data, param, key \} = params const res 悠悠/ 2023年02月18日 03:05/ 0 赞/ 33 阅读
相关 AES 加密 import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.c 秒速五厘米/ 2022年12月29日 15:28/ 0 赞/ 183 阅读
相关 AES加密 package com.test.util.encrypt; import org.apache.commons.lang3.StringUtil 小咪咪/ 2022年07月15日 20:43/ 0 赞/ 248 阅读
相关 AES加密 AES加密是一种对称加密,即加密秘钥与解密秘钥相同 示例如下: public class Aes { //算法 private st 偏执的太偏执、/ 2022年04月14日 05:14/ 0 赞/ 275 阅读
相关 AES加密 import java.io.UnsupportedEncodingException; import java.security.InvalidKeyExce 小灰灰/ 2022年03月09日 14:46/ 0 赞/ 289 阅读
相关 AES加密 AES技术是一种对称的分组加密技术,使用128位分组加密数据,提供比WEP/TKIPS的RC4算法更高的加密强度。AES的加密码表和解密码表是分开的,并且支持子密钥加密,这种 ゞ 浴缸里的玫瑰/ 2022年02月15日 00:09/ 0 赞/ 297 阅读
相关 Python AES加密 与 JS AES加密 import execjs from Crypto.Cipher import AES from binascii import b2a_hex, a2 「爱情、让人受尽委屈。」/ 2021年12月20日 11:55/ 0 赞/ 379 阅读
相关 AES加密 介绍 AES是一种对称加密,使用同一个密钥来加密和解密一段密文 安装 pip install pycryptodome 基础语法 aes 今天药忘吃喽~/ 2021年12月09日 04:49/ 0 赞/ 334 阅读
相关 AES加密算法 AES加密算法是对称密钥加密中最流行的算法之一 这是我转自CSDN博客的详细解析: 一般的加密通常都是块加密,如果要加密超过块大小的数据,就需要涉及填充和链 比眉伴天荒/ 2021年09月10日 16:14/ 0 赞/ 520 阅读
还没有评论,来说两句吧...