很多同学学习《node建站攻略(二期)》课程时,遇到注册用户时无法保存加密后的密码的问题。写法大概如下:
var bcrypt = require('bcrypt-nodejs');
// 此处省略无关代码...
bcrypt.hash(user.password, null, null, function (err, hash) {
user.password = hash; // 注意:这里是异步执行的
next();
});
我理解的出错的原因是 user.password = hash;
这一步是异步执行的,还没将加密后的值赋值给 user.password
属性时,明文密码已经保存到数据库了。因此,在做登录验证密码时,拿明文密码和加密后的密码比较,自然也就无法通过验证。
可以参考以下写法:
UserSchema.pre('save', function (next) {
// 此处省略无关代码...
var hash = bcrypt.hashSync(this.password);
this.password = hash; // 注意:这里是同步执行的
next();
});
UserSchema.methods = {
comparePassword: function (_password, cb) {
var hash = this.password;
var isMatch = bcrypt.compareSync(_password, hash);
cb(null, isMatch);
}
};
注:本人也是在 node.js 学习阶段,如果理解有误,敬请指正。
點(diǎn)擊查看更多內(nèi)容
1人點(diǎn)贊
評(píng)論
評(píng)論
共同學(xué)習(xí),寫(xiě)下你的評(píng)論
評(píng)論加載中...
作者其他優(yōu)質(zhì)文章
正在加載中
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得
100積分直接送
付費(fèi)專(zhuān)欄免費(fèi)學(xué)
大額優(yōu)惠券免費(fèi)領(lǐng)