import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;
public class AESUtil {
/**
* 加密字符串
* @param s 需要加密的字符串
* @param key 密钥
* @return 加密后的字符串
*/
public static String encrypt(String s, String key) {
try {
// 创建AES加密算法
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
// 创建密钥
SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
// 初始化加密算法
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
// 进行加密
byte[] encryptedBytes = cipher.doFinal(s.getBytes(StandardCharsets.UTF_8));
// 使用Base64编码加密后的字节流
return Base64.getEncoder().encodeToString(encryptedBytes);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
/**
* 解密字符串
* @param s 需要解密的字符串
* @param key 密钥
* @return 解密后的字符串
*/
public static String decrypt(String s, String key) {
try {
// 创建AES解密算法
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
// 创建密钥
SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
// 初始化解密算法
cipher.init(Cipher.DECRYPT_MODE, secretKey);
// 解码Base64编码后的字符串
byte[] encryptedBytes = Base64.getDecoder().decode(s);
// 进行解密
byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
// 将解密后的字节流转换为字符串
return new String(decryptedBytes, StandardCharsets.UTF_8);
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
public static void main(String[] args) {
String str = "{\"user_mail\": \"liqinglin0314@aliyun.com\",\"nickName\": \"Allen\", \"user_psw\": \"123456\", \"user_sex\": \"1\"}";
String key = "1234567890123456";
System.out.println("加密前:" + str);
String encryptedStr = encrypt(str, key);
System.out.println("加密后:" + encryptedStr);
String decryptedStr = decrypt(encryptedStr, key);
System.out.println("解密后:" + decryptedStr);
System.out.println(str.equals(decryptedStr) ? "解密成功" : "解密失败");
}
}