可参考:https://blog.csdn.net/qq_40673786/article/details/90480352
代码可参考:
public class AesEncryptUtils {
private static final Logger LOG = LoggerFactory.getLogger(AesEncryptUtils.class);
// 可配置到Constant中,并读取配置文件注,自己定义
private static final String KEY = "mQINBF2EsxoDEACy";
// 参数分别代表 算法名称/加密模式/数据填充方式
private static final String ALGORITHMSTR = "AES/ECB/PKCS5Padding";
/**
* 加密
* @param content 加密的字符串
* @param encryptKey key
* @return
* @throws Exception
*/
public static String encrypt(String content, String encryptKey) throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
kgen.init(128);
Cipher cipher = Cipher.getInstance(ALGORITHMSTR);
cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(encryptKey.getBytes(), "AES"));
byte[] b = cipher.doFinal(content.getBytes("utf-8"));
// 采用base64算法进行转码,避免出现中文乱码
return Base64.encodeBase64String(b);
}
/**
* 解密
* @param encryptStr 解密的字符串
* @param decryptKey 解密的key?
* @return
* @throws Exception
*/
public static String decrypt(String encryptStr, String decryptKey) throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
kgen.init(128);
Cipher cipher = Cipher.getInstance(ALGORITHMSTR);
cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(decryptKey.getBytes(), "AES"));
// 采用base64算法进行转码,避免出现中文乱码
byte[] encryptBytes = Base64.decodeBase64(encryptStr);
byte[] decryptBytes = cipher.doFinal(encryptBytes);
return new String(decryptBytes);
}
public static String encrypt(String content) {
String result;
try {
result = encrypt(content, KEY);
}
catch (Exception e) {
result = content;
LOG.error("encrypt failed:" + e.getMessage());
}
return result;
}
public static String decrypt(String encryptStr) {
String result;
try {
result = decrypt(encryptStr, KEY);
}
catch (Exception e) {
result = encryptStr;
LOG.error("decryption failed:" + e.getMessage());
}
return result;
}
}