这是服务器端的加密AES加密代码。我怎么能decrypt in javascript
。我找不到任何具有填充的iv和key的解密逻辑。
public static String encrypt(String key, String initVector, String value) {
try {
IvParameterSpec iv = new IvParameterSpec("l353b3l3jk3bk3j3".getBytes("UTF-8"));
SecretKeySpec skeySpec = new SecretKeySpec("2353c3l3jk3bk3j8".getBytes("UTF-8"), "AES");
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);
byte[] encrypted = cipher.doFinal(value.getBytes());
System.out.println("encrypted string: " + Base64.encodeBase64String(encrypted));
return Base64.encodeBase64String(encrypted);
} catch (Exception ex) {
ex.printStackTrace();
}
return null;
}
答案 0 :(得分:0)
您可以通过以下方式使用CryptoJS:
var decryptedData = CryptoJS.AES.decrypt(cipherText, CryptoJS.enc.Base64.parse(key),
{
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7 //default
});
console.log('Decrypted Data: ' + decrypted);
此库不支持PKCS5,但您不应该使用它,因为它是为DES而非AES而设计的。但是,如果您不想更改它,那么您仍然可以使用PKCS7进行解密,它将起作用,因为差异在于块填充支持的块大小。 PKCS5仅适用于8字节块,而PKCS7适用于1到255字节之间的块大小。 DES使用8字节的块大小。