javascript – AES / CBC / PKCS5PADDING IV – 从Java到NodeJ的解密
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – AES / CBC / PKCS5PADDING IV – 从Java到NodeJ的解密,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1739字,纯文字阅读大概需要3分钟。
内容图文
![javascript – AES / CBC / PKCS5PADDING IV – 从Java到NodeJ的解密](/upload/InfoBanner/zyjiaocheng/718/cea8ad8bfeb14313b79c01e8e4412d04.jpg)
我想在NodeJs中解密.它在Java中工作.但是我无法在Node中实现相同的功能.
我使用的是node-version:8.4
请找到我的NodeJs代码:
var crypto = require('crypto');
function decryption (message, key) {
var messageArray = Buffer.from(message, 'base64');
// var kekbuf = Buffer(key, 'utf8');
var ivBuffer = new Buffer([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]);
var iv = ivBuffer.slice(0, 16);
var decipher = crypto.createDecipheriv('aes-256-cbc', key, iv);
decipher.setAutoPadding(false);
var dec = decipher.update(messageArray, 'base64');
dec += decipher.final();
return dec.toString();
}
请找到有用的Java代码
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import javax.xml.bind.DatatypeConverter;
class Test1 {
public String decrypt(String message, String key) throws Exception {
DatatypeConverter dtc = null;
byte[] messagArray = dtc.parseBase64Binary(message);
byte[] keyArray = dtc.parseBase64Binary(key);
byte[] iv = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
IvParameterSpec ivspec = new IvParameterSpec(iv);
SecretKey secretKey = new SecretKeySpec(keyArray, "AES");
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
cipher.init(Cipher.DECRYPT_MODE, secretKey, ivspec);
return new String(cipher.doFinal(messagArray));
}
}
我得到一个不同的解密文本.我无法在NodeJ中获得与Java相同的结果.
请帮我解决一下这个.
解决方法:
使用crypto2库,这个库修复了iv问题:
const crypto2 = require('crypto2');
AESDecrypt: function (encrypted, secretKey) {
return new Promise((resolve, reject) => {
if (encrypted && secretKey) {
crypto2.decrypt.aes256cbc(encrypted, secretKey, (err, decrypted) => {
if (err) {
reject(err);
} else {
resolve(decrypted);
}
});
} else {
reject('Crypt - Invalid params!');
}
})
}
内容总结
以上是互联网集市为您收集整理的javascript – AES / CBC / PKCS5PADDING IV – 从Java到NodeJ的解密全部内容,希望文章能够帮你解决javascript – AES / CBC / PKCS5PADDING IV – 从Java到NodeJ的解密所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。