import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;
public class AESUtil {
// 解密方法
public static String decrypt(String encryptedData, String key) throws Exception {
// 创建AES解密器
Cipher cipher = Cipher.getInstance("AES");
// 将Base64编码的密钥转换为字节数组并生成SecretKeySpec对象
SecretKeySpec secretKey = new SecretKeySpec(Base64.getDecoder().decode(key), "AES");
// 初始化解密器
cipher.init(Cipher.DECRYPT_MODE, secretKey);
// 将Base64编码的加密数据转换为字节数组并进行解密
byte[] decryptedBytes = cipher.doFinal(Base64.getDecoder().decode(encryptedData));
// 返回解密后的字符串
return new String(decryptedBytes);
}
// 生成密钥的方法(仅用于测试)
public static String generateKey() throws Exception {
KeyGenerator keyGen = KeyGenerator.getInstance("AES");
keyGen.init(128); // 可以选择192或256,但需要额外的JCE无限制权限策略文件
SecretKey secretKey = keyGen.generateKey();
return Base64.getEncoder().encodeToString(secretKey.getEncoded());
}
public static void main(String[] args) {
try {
// 测试解密
String key = generateKey(); // 生成密钥
String encryptedData = "your_encrypted_data_here"; // 替换为实际的加密数据
String decryptedData = decrypt(encryptedData, key);
System.out.println("Decrypted Data: " + decryptedData);
} catch (Exception e) {
e.printStackTrace();
}
}
}
javax.crypto
包中的类来处理AES加密和解密。decrypt
方法:该方法接收两个参数:加密后的数据和密钥。它首先将Base64编码的密钥和加密数据转换为字节数组,然后使用AES算法进行解密,并返回解密后的字符串。generateKey
方法:用于生成一个随机的AES密钥,并将其转换为Base64编码的字符串。这在测试时非常有用。main
方法:演示如何使用上述方法进行解密。请确保替换your_encrypted_data_here
为实际的加密数据,并根据需要调整密钥长度和其他参数。
上一篇:java lastindexof
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站