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) 进行处理。用不正确的密钥解密当然会失败。
确保在解密失败时关闭填充,并查看生成的明文是否有意义。
美好的一天。我想使用 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) 进行处理。用不正确的密钥解密当然会失败。
确保在解密失败时关闭填充,并查看生成的明文是否有意义。