JavaScript中的AES加密和Java中的解密

岑兹0

我有一个现有的网络服务,可以使用AES进行加密和解密,现在我必须以与Java相同的方式进行加密,但是要使用javascript。我已经阅读了有关在javascript中执行此操作的所有主题,但尚未找到任何有用的解决方案。Javascript总是以不同的方式加密,我找不到原因。

这是现有的java代码:

public static String encrypt(String data) throws Exception {
    byte[] keyValue = encryptionKey.getBytes();
    Key key = new SecretKeySpec(keyValue, "AES");
    Cipher c = Cipher.getInstance("AES/ECB/PKCS5Padding");
    c.init(Cipher.ENCRYPT_MODE, key);
    byte[] encVal = c.doFinal(data.getBytes());
    String encryptedValue = new BASE64Encoder().encode(encVal);
    return encryptedValue;
}

这是我倾向于使用的javascript代码,但是提供了不同的加密(CryptoJS):

var encrypted = CryptoJS.AES.encrypt(data, encryptionKey);

或以下任何一种(GibberishAES):

// Defaults to 256 bit encryption
var encrypted = GibberishAES.enc(data, encryptionKey);
// change the bit encrytion
GibberishAES.size(128);
var encrypted = GibberishAES.enc(data, encryptionKey);
GibberishAES.size(192);
var encrypted = GibberishAES.enc(data, encryptionKey);

我无法更改Java中的实现或我们进行安全性处理的方式。有人在这方面有更多经验可以告诉我我在做什么错吗?

霍尔格

您只在查看加密算法,但也要注意块模式和填充,否则将不会创建兼容的结果。根据code.google.com的说法,CryptoJS的默认值为CBC和,PKCS7而您的Java代码使用ECBPKCS5

您必须将其匹配。您可以设置CryptoJS以使用ECB关于填充,因为CryptoJS不会列出PKCS5受支持的内容,而Java没有列出PKCS7,实际上它列出的内容很少,因此更加棘手,因此实现可能取决于AES提供程序支持哪种填充算法,但至少NoPadding两者都支持, Java和CryptoJS。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章