我一直在尝试使用Passport-local和node.js进行一些身份验证。但是,我继续收到以下错误:
Error: Can't set headers after they are sent.
at ServerResponse.OutgoingMessage.setHeader (http.js:689:11)
at ServerResponse.header (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/express/lib/response.js:717:10)
at ServerResponse.res.location (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/express/lib/response.js:831:8)
at ServerResponse.redirect (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/express/lib/response.js:870:8)
at complete (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/middleware/authenticate.js:241:26)
at /home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/middleware/authenticate.js:250:15
at pass (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/authenticator.js:427:14)
at Authenticator.transformAuthInfo (/home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/authenticator.js:449:5)
at /home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/middleware/authenticate.js:247:22
at /home/denny/workspace/nodejs-ecommerce/e-shop/node_modules/passport/lib/http/request.js:51:7
我的代码如下:
passport.use(new LocalStrategy({usernameField:'email', passwordField: 'password'},
function(email, password, done) {
User.find({ where: { email: email }}).success(function(user) {
if (!user) {
done(null, false, { message: 'Unknown user' });
}
else if (password != user.password) {
done(null, false, { message: 'Invalid password'});
}
else {
done(null, user);
}
}).error(function(err){
done(err);
});
return done(null, false);
}
));
答案 0 :(得分:3)
您正在两次调用done()
回调。在你的if语句中,然后是最后一个。
最后一个是不需要的,因为你的if / else和成功/错误的逻辑总是应该做点什么。
passport.use(new LocalStrategy({
usernameField: 'email',
passwordField: 'password'
},
function(email, password, done) {
User.find({
where: {
email: email
}
}).success(function(user) {
if (!user) {
done(null, false, {
message: 'Unknown user'
});
} else if (password != user.password) {
done(null, false, {
message: 'Invalid password'
});
} else {
done(null, user);
}
}).error(function(err) {
done(err);
});
}
));