Passport.js在Node.js中提供了身份验证框架。它只处理身份验证。
现在我想启用密码重置。由于用户模型中没有密码字段,只有passports字段,如何在passport-local策略中重置密码?我假设用户需要生成一个新密码,并调用一些东西来覆盖旧密码的现有散列。这些方法是什么?我在哪里可以找到它们?
发布于 2015-06-26 22:11:56
当用户选择重置其密码时,您可以执行的操作是向该用户发送一封电子邮件,其中包含一个包含与该用户关联的令牌的链接。一旦用户单击了链接,您就可以根据令牌和电子邮件验证用户,然后显示重置密码HTML。一旦用户输入了新密码,在后台代码中,您可以在散列后在User对象上设置密码,然后保存密码。您也可以将令牌设置为null。
使用base64的示例代码如下所示
user.salt = new Buffer(crypto.randomBytes(16).toString('base64'), 'base64');
user.password = user.hashPassword('newPassword');
user.token = undefined;
user.save(...)hashPassword方法如下所示。
UserSchema.methods.hashPassword = function(password) {
if (this.salt && password) {
return crypto.pbkdf2Sync(password, this.salt, 10000, 64).toString('base64');
} else {
return password;
}
};上面的代码是用Yeoman自动生成的
https://stackoverflow.com/questions/31075130
复制相似问题