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) ? "解密成功" : "解密失败"); } }