NodeJS AES 256 十六进制解密错误

NodeJS AES 256 hex decrypt error

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

十六进制: 820D4DA01CE75046C399CA314C5428C6AF8D69C6573B4DE5A6942A5277936F56
密钥: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 与算法、密钥和 IV 参数一起使用。 IV 可能会被忽略,但为了保险起见,将其设置为 16 个零字节。如果您使用两个参数函数,则密钥将通过基于密码的密钥派生函数 (PBKDF) 进行处理。用不正确的密钥解密当然会失败。

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