CryptoJS和Java进行加解密

使用AES加密算法时CryptoJS无法对Java的十六进制的AES的字符串的密文进行解密的问题。

在使用CryptoJS进行前后端加密时。使用CryptoJS对java的16进制的aes的字符串密文进行解密遇到无法进行解密。在测试过程中我对同一个消息进行加密,获得了同样的密文。在这种情况下CryptoJS不能Java进行解密时不可能的。在思考了几分钟,我对CryptoJS加解密对象进行查看它们的原型。它们都属于object,在仔细查看中,发现他们的属性和使用CryptoJS.enc.Hex.parse()进行包装的对象一样。我对java的密文使用CryptoJS.enc.Hex.parse()进行包装,得到的对象传入到process(encryptor);中,正确获得加密后的明文。

 1 var key = CryptoJS.enc.Hex.parse("fe4c2807af7c26924af5e0dae82c2209");
 2 var iv = CryptoJS.enc.Hex.parse("d67038555ecb505db3b9d06852da2641");
 3 var aesDecryptor = CryptoJS.algo.AES.createDecryptor(key, {
 4     iv: iv,
 5     mode: CryptoJS.mode.CBC,
 6     padding: CryptoJS.pad.Pkcs7
 7 });
 8 var aesEncode = CryptoJS.enc.Hex.parse("e8a282ac9cbd9d2614f91f20c4e9b598");
 9 aesDecryptor.process(aesEncode);
10 var aesDecode = aesDecryptor.finalize();
11 console.log(aesDecode.toString(CryptoJS.enc.Utf8))

 

转载于:https://www.cnblogs.com/blueSkyBlog/p/10801780.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值