我想了解LocalStrategy是如何运作的。
以下是我的服务器文件的一部分:
var passport = require('passport');
var express = require('express');
/* other initializations */
var app = express();
passport.use = new LocalStrategy(
function(email, password, done) {
module.exports.findByUsername(email, function(err, user){
if (err) throw err;
if(!user) {
done(null, false, { message: 'Incorrect username.' });
}
else if(user.password != password) {
done(null, false, { message: 'Incorrect password.' });
}
else {
return done(null, user);
}
});
}
)
app.post("/login"
, passport.authenticate('local',{
successRedirect : "/",
failureRedirect : "/login",
}) ,
function(){
console.log("post /login");
}
);
现在,从客户端浏览器,我发送一个http post请求到http://localhost:8000/login
。如果身份验证成功,则用户将被重定向到根页"/"
,如果失败,用户将被重定向到登录页面。
问题是,当我们定义新的LocalStrategy时,我定义了一个function(email,password, done){...}
。但是,当我在app.post("/login", ...){...}
调用此函数时,如何传递电子邮件和密码参数?
答案 0 :(得分:1)
护照会假定您使用input name='username'
input name='password'
发布表单。按照passport docs:
passport.use(new LocalStrategy({
usernameField: 'email',
passwordField: 'password'
},
function(email, password, done) {
// ...
}
));