gpt4 book ai didi

node.js - NodeJS AES 256 十六进制解密错误

转载 作者:太空宇宙 更新时间:2023-11-03 21:59:55 27 4
gpt4 key购买 nike

美好的一天。我想使用 nodejs 模块 crypto 来解码先前编码的字符串。字符串使用 AES 256 ECB 编码,我将其设置为十六进制。我所有的尝试几乎什么也没做,只是有时我得到空字符串而不是错误。我仅“需要”加密,不需要 open-ssl。

十六进制:820D4DA01CE75046C399CA314C5428C6AF8D69C6573B4DE5A6942A5277936F56
key :7y05R9qwKaIKgIHh4vAw19X1zuknR21Y

这是我的nodejs代码。

var algorithm = 'aes-256-ecb',
password = '7y05R9qwKaIKgIHh4vAw19X1zuknR21Y',
encString = '820D4DA01CE75046C399CA314C5428C6AF8D69C6573B4DE5A6942A5277936F56'

var decipher = crypto.createDecipher(algorithm,password);
var dec = decipher.update(encString,'hex','utf8');
dec += decipher.final('utf8');
console.log(dec);

我有这个错误。

Error: error:06065064:digital envelope routines:EVP_DecryptFinal_ex:bad decrypt.

需要您的帮助。

更新

经过几个小时和来自 Maarten Bodewes 和 this topic 的无价建议,这是可行的解决方案。

var encString=req.query.d;
console.log(encString);

var algorithm = 'aes-256-ecb',
password = new Buffer('7y05R9qwKaIKgIHh4vAw19X1zuknR21Y', 'binary');

var decipher=crypto.createDecipheriv(algorithm, password.toString('binary'), '');
decipher.setAutoPadding(false);
var dec = decipher.update(encString,'hex','utf8');
dec += decipher.final('utf8');

console.log(dec);

最佳答案

您必须将 createDecipher 与算法、 key 和 IV 参数一起使用。 IV 可能会被忽略,但为了确定起见,将其设置为 16 个零字节。如果您使用两个参数函数,则 key 将通过基于密码的 key 派生函数 (PBKDF) 进行处理。使用不正确的 key 解密当然会导致失败。

如果解密失败,请确保关闭填充,并查看生成的明文是否有意义。

关于node.js - NodeJS AES 256 十六进制解密错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29550509/

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