我正在尝试使用nodeJs和MySql登录用户
这是我连接用户的功能:
export async function connectUser(email, password, cb) {
console.log('Entry connectuser');
let db = dbConnect();
await db.query('SELECT id, email, password FROM user WHERE email = ?', [email], async (error, result) => {
if (error) return cb(error);
const user = result[0];
console.log(result);
console.log(user.email);
console.log(user.password);
console.log(user.id);
const isValid = await bcrypt.compare(password, user.password);
if (isValid === true) {
const token = jwt.sign({id: user.id, email: user.email }, secret, {expiresIn: 86400 });
return cb(null, token);
}
return cb(new Error('Invalid Credentials'));
});
我在bcrypt.compare()上收到此错误:“ UnhandledPromiseRejectionWarning:错误:非法参数:object,string”
我想这是async / await的错误,但我无法解决...一些想法?
如文档中所述,您应使用bcrypt.compare这样的:
bcrypt.compare(req.body.password,user.password, function(err, res) {
if (err){
// handle error
}
if (res)
// Send JWT
} else {
// response is OutgoingMessage object that server response http request
return response.json({success: false, message: 'passwords do not match'});
}
});
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句