我已经阅读了很多有关Node crypto模块的pbkdf2()函数的文档。我之前提出的一个问题没有经过深思熟虑就被折叠了-所以让我这样说:我认为我对回调没有足够的了解-但是我已经读了很多试图真正理解它的资源-YDKJS Async,MDN,“学习JavaScript “由O'Reilly提供。
我在适当记录的回调函数的else子句中有一个console.log语句,因此尽管我的调试程序(在VSCode中)没有停止执行,但是我确定该回调函数正在执行。
我尝试了两种不同的方法,如下面的代码所示:一种是声明一个变量并将其值更改为else子句中的derivedKey.toString('hex'),另一种是返回derivedKey.toString。 (“十六进制”)。都不起作用。
我尝试链接一个then子句,但是crypto.pbkdf2返回void,并且“ void”类型不存在属性'then'。
这里是书面方法:
private static async hashPassword(password:string, salt:string):Promise<string> {
var hashedPassword;
const iterations = 50000;
const keylen = 64;
const digest = 'sha512';
const possibleReturnedValue = await crypto.pbkdf2(password, salt, iterations, keylen, digest, (err, derivedKey) => {
if (err) {throw err;}
else {
console.log(derivedKey.toString('hex'));
console.log("Hey now");
hashedPassword = derivedKey.toString('hex');
return derivedKey.toString('hex');
}
})
return hashedPassword;
}
真正的结果是:我不知道如何从通过回调返回'void'的函数中获取导出的Key.toString('hex')值。
您的问题是crypto.pbkdf2
函数有些陈旧,并且不能使用promise而是使用回调。因此,为了在现代异步代码中使用此函数,必须将该函数包装在Promise
对象中。
关键思想是在回调中调用promise的构造函数提供的resolve
和reject
函数。
重构为返回承诺,您的函数将如下所示:
function hashPassword(password:string, salt:string):Promise<string> {
return new Promise((resolve, reject) => {
const iterations = 50000;
const keylen = 64;
const digest = 'sha512';
crypto.pbkdf2(password, salt, iterations, keylen, digest, (err, key) => {
if (err) {
reject(err);
} else {
resolve(key.toString('hex'));
}
})
});
}