gpt4 book ai didi

使用 cryptojs 的 Java 到 JS 和 JS 到 Java 加密

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:27:26 25 4
gpt4 key购买 nike

我几周前开始写这篇文章并且工作得很好: Compatible AES algorithm for Java and Javascript

现在,我需要进行反向操作,但是在 java 中,我得到了这个异常:

javax.crypto.BadPaddingException: Given final block not properly padded
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:966)
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:824)
at com.sun.crypto.provider.AESCipher.engineDoFinal(AESCipher.java:436)
at javax.crypto.Cipher.doFinal(Cipher.java:2165)

这是我在 JavaScript 中进行的“反向”操作:

var rkEncryptionKey = CryptoJS.enc.Base64.parse('u/Gu5posvwDsXUnV5Zaq4g==');
var rkEncryptionIv = CryptoJS.enc.Base64.parse('5D9r9ZVzEYYgha93/aUK2w==');

function encryptString(stringToEncrypt) {
var utf8Stringified = CryptoJS.enc.Utf8.parse(stringToEncrypt);
var encrypted = CryptoJS.AES.encrypt(utf8Stringified.toString(), rkEncryptionKey, {mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7, iv: rkEncryptionIv});
return CryptoJS.enc.Base64.parse(encrypted.toString()).toString();
}

我以为这就是全部?

[编辑]

加密字符串如下:{"company_name":"asdfasdfasd","customer_name":"asdfasdfasdfasdf","phone_number":"asdfasdfasdfasdf","email":"asdfasdfasdfasdfads"

当从 java 到 java 进行加密/解密时,它可以工作,当从 java 到 javascript 时,也可以,但是从 javascript 到 java,则不起作用。

Java 代码

public String toJson(final String encrypted) {
try {
SecretKey key = new SecretKeySpec(Base64.decodeBase64("u/Gu5posvwDsXUnV5Zaq4g=="), "AES");
AlgorithmParameterSpec iv = new IvParameterSpec(Base64.decodeBase64("5D9r9ZVzEYYgha93/aUK2w=="));
byte[] decodeBase64 = Base64.decodeBase64(encrypted);

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, key, iv);

return new String(cipher.doFinal(decodeBase64), "UTF-8");
} catch (Exception e) {
throw new RuntimeException("This should not happen in production.", e);
}
}

最佳答案

改变

return CryptoJS.enc.Base64.parse(encrypted.toString()).toString();

return encrypted.ciphertext.toString(CryptoJS.enc.Base64);

encrypted 对象通常字符串化为 OpenSSL 格式,其中也可能包含盐。如果您只对实际的密文感兴趣,那么您需要对 ciphertext 属性进行字符串化。

请注意,toString() 采用可选的编码函数。使用您需要的那个。

关于使用 cryptojs 的 Java 到 JS 和 JS 到 Java 加密,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30382014/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com