我遇到了一个问题,当我尝试使用护照登录时,页面没有重定向。授权返回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
错误的格式返回?任何帮助都会很棒。