我的 MongoDB 中有一个简单的用户集合。我使用 mongo-native 驱动程序。
{
"email": "johndow@example.com",
"password": "123456",
"_id": {
"$oid": "50658c835b821298d3000001"
}
}
当我通过pair email:pass 进行用户身份验证时,我将默认的passport-local 函数findByUsername 重写为:
function findByEmail(email, fn) {
db.collection("users", function(err, collection) {
collection.find({}, {}, function(err, users) {
users.each(function(err, user) {
if (user.email === email) {
return fn(null, user);
}
});
return fn(null, null);
});
});
}
只需从数据库中获取所有用户,并检查 - 如果 user.email == 提供了电子邮件,则返回用户对象。
我使用 MongoDB 的 _id 参数作为用户的 id,这就是我修改这两个函数的原因:
passport.serializeUser(function(user, done) {
done(null, user._id);
});
passport.deserializeUser(function(id, done) {
findById(id, function(err, user) {
done(err, user);
});
});
这是我的护照本地策略代码:
passport.use(new LocalStrategy( function(email, password, done) {
process.nextTick(function() {
console.log('initialize findByEmail() for "',email,'"');
findByEmail(email, function(err, user) {
if (err) {
return done(err);
}
if (!user) {
console.log('Unknown user ' + email)
return done(null, false, {
message: 'Unknown user ' + email
});
}
if (user.password != password) {
console.log('Invalid password')
return done(null, false, {
message: 'Invalid password'
});
}
//сonsole.log('ALL VERIFIATION PASSED');
return done(null, user);
})
});
}));
我从登录页面发布数据:
app.post('/login', passport.authenticate('local', {
failureRedirect: '/',
failureFlash: true
}), function(req, res) {
res.redirect('/desk');
});
我得到
Error: Can't set headers after they are sent.
在此之后我得到
TypeError: Cannot read property 'email' of null
最后一个错误真的很奇怪,因为 findByEmail 有 console.log(user) 行(从这个列表中删除)并且它列出了所有用户的数据。
我究竟做错了什么?