我试图用AES解密一些数据。我已经拥有一个256位密钥和16字节IV这样的:JAVA AES 256解密
String key = "Hh1s1f4T2mpN3yCh4ngeL8t3r\\.Thxpp";
int[] v = {11, 1, 555, 222, 241, 21, 11, 33, 35, 91, 45, 6, 14, 30, 22, 234};
String IV = Arrays.toString(v);
我已经告诉填充应该是PKCS7但是当我初始化密码与AES/CBC/PKCS7PADDING
它说:Cannot find any provider supporting AES/CBC/PKCS7PADDING
如果我用AES/CBC/PKCS5PADDING
我得到Illegal key size
但我检查,关键尺寸为32
public static String decrypt(String key, String initVector, String encrypted) {
try {
System.out.println("Key size: " + key.getBytes("UTF-8").length);
IvParameterSpec iv = new IvParameterSpec(initVector.getBytes("UTF-8"));
SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), "AES");
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);
byte[] original = cipher.doFinal(Base64.decodeBase64(encrypted));
return new String(original);
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}
感谢您的澄清,这解决了这个问题。很有趣,我们的生产环境确实包含了很多其他人所报道的这些库。生产中的差异在于使用OpenJDK vs使用Oracle的开发。 –