0

我正在尝试使用加密模块在 node.js 中实现加密。下面是我的代码片段:

var SECRET_KEY = "RANDOMKEY";
var crypto = require("crypto");
var MD5 = crypto.createHash("MD5");
MD5.update(SECRET_KEY, 'ucs2');
var hash = MD5.digest('binary');


var key = new Buffer(hash, 'binary');
var keyStart = new Buffer(8, 'binary');
key.copy(keyStart, 0, 0, 8);


var valueToEncrypt = new Buffer('password', 'utf-8').toString('binary');
var cipher = crypto.createCipheriv('des-cbc',keyStart, keyStart);
var cryptedPassword = cipher.update(valueToEncrypt, 'binary', 'base64');

cryptedPassword+= cipher.final('base64');

console.log(cryptedPassword);gives---> r4xhQ8T87z2FFkLOxkcnGg==

我应该得到的是r4xhQ8T87z26w30I1vr9kA== 我不确定我在这里做错了什么。非常感谢任何帮助。

4

1 回答 1

1

事实证明,它正在正确加密,您的预期值仅包含"\r\n"密码后的 a,此示例代码未提供。

"r4xhQ8T87z2FFkLOxkcnGg=="解密为"password""r4xhQ8T87z26w30I1vr9kA=="解密为"password\r\n".

有了这个,你对编码有点疯狂。将所有内容保存为Buffer.

var SECRET_KEY = "RANDOMKEY";
var crypto = require("crypto");

var MD5 = crypto.createHash("MD5");
MD5.update(SECRET_KEY, 'ucs2');
var keyStart = MD5.digest().slice(0, 8);

var valueToEncrypt = 'password\r\n';
var cipher = crypto.createCipheriv('des-cbc', keyStart, keyStart);
var cryptedPassword = cipher.update(valueToEncrypt, 'utf8', 'base64') +
    cipher.final('base64');

console.log(cryptedPassword);
于 2013-04-26T06:06:00.340 回答