我遇到了一个问题,当我尝试使用护照登录时,页面不会重定向。授权返回true
(正确的用户名,密码)。
我很确定它位于validPassword
函数中的某个位置,但我不确定。
登录路线
app.get('/login', function (req, res) {
res.render('login', {});
});
登录信息
app.post('/login',
passport.authenticate('local', { successRedirect: '/',
failureRedirect: '/login' }));
用户原型
User.prototype.validPassword = function(username, unhashedPassword) {
async.waterfall([
function (callback) {
User.find({ "username" : username }, function (err, data) {
if(err) return handleError(err);
callback(null, data);
});
},
function (data, callback) {
var isGood = passwordHash.verify(unhashedPassword, data[0].password);
callback(null, isGood);
}
], function (err, result) {
return result;
});
};
本地策略
passport.use(new LocalStrategy(
function(username, password, done) {
var unhashedPassword = password;
var passedUsername = username;
User.findOne({ username: username }, function(err, user) {
if (err) { return done(err); }
if (!user) {
return done(null, false, { message: 'Incorrect username.' });
}
if (!user.validPassword(passedUsername, unhashedPassword)) {
return done(null, false, { message: 'Incorrect password.' });
}
return done(null, user);
});
}
));
我的控制台上没有打印错误,所以我现在有点困惑。 isGood
可能以错误的格式返回吗?任何帮助都会很棒。
答案 0 :(得分:5)
我发现了我的问题。问题在于我的本地策略和我的validPassword
原型。
在我的策略中,我有一个console.log
说错误,用户名无效或错误,密码无效。我的console.log
打印了对prototype
的评价,我也有一个passwordHash.verify(unhashedPassword, this.password)
。
当我发布登录时,控制台将打印如下:
LOG: valid username (Strategy)
LOG: invalid password (Strategy)
LOG: true (Prototype)
遵循逻辑流程,LOG: true (prototype)
应出现在LOG: invalid password (Strategy)
之前,但它出现之后意味着某处出现了同步问题。
好吧,我通过删除大约15行代码解决了问题,现在它的工作方式就像一个漂亮的。
这就是我的auth策略现在的样子。
<强> User.prototype.validPassword 强>
User.prototype.validPassword = function(unhashedPassword) {
return passwordHash.verify(unhashedPassword, this.password);
};
<强> LocalStrategy 强>
passport.use(new LocalStrategy({
usernameField: 'username',
passwordField: 'password'
},
function(username, password, done) {
var unhashedPassword = password;
var passedUsername = username;
process.nextTick(function () {
User.findOne({ username: passedUsername }, function(err, user) {
console.log('within local strategy', user);
if (err) {
console.log('Error:', err);
return done(err);
}
if (!user) {
console.log('Incorrect username:');
return done(null, false, { message: 'Incorrect username.' });
}
if (!user.validPassword(unhashedPassword)) {
return done(null, false, { message: 'Incorrect password.' });
}
return done(null, user);
});
});
}
));
POST登录
app.post('/login',
passport.authenticate('local', { failureRedirect: '/login' }),
function(req, res) {
res.redirect('/');
});