我是快递新手,我试图用护照实施一些身份验证方法。对我来说这似乎是最好的选择,我开始阅读几个教程,现在我有这个不寻常的代码。 显然,未使用策略 registerStrategy ,因为 console.log(" log"); 未显示在服务器的控制台中。 节点不会抛出任何错误。
//localStrategy.js
var registerStrategy = new localStrategy(
function(req, res, done){
console.log("log");
var user = {
username: req.user.username,
password: req.user.password,
name: req.body.user.name,
lastname: req.body.user.lastname,
email: req.body.user.email,
event_time: req.body.user.event_time
};
var usernameExists = true, emailExists = true;
var tasks = [
function(cb){
db.usernameExists(user.username, function(err, exists){
if(err) return cb(err);
usernameExists = exists;
cb();
});
},
function(cb){
db.emailExists(user.email, function(err, exists){
if(err) return cb(err);
emailExists = exists;
cb();
});
}
];
async.parallel(tasks, function(err){
if(err) return done(err);
if(usernameExists || emailExists){
return done(null, usernameExists, emailExists);
}
done(null, null, null);
});
}
);
app.use(session(sessionData));
passport.use("local-register", registerStrategy);
//routes.js
app.post("/api/register", function(req, res){
passport.authenticate("local-register")(req, res,
function(err, usernameExists, emailExists){
if(err) throw err;
if(usernameExists){
return res.status(401).json({ err: "User exists"});
}
else if(emailExists){
return res.status(401).json({ err: "Email exists"});
}
res.status(200).json({status: "Succesful"});
}
);
});

我的错误在哪里?
答案 0 :(得分:0)
passport.authenticate(...)
是一个返回middleware
函数的函数,因此第三个参数是对下一个middleware
函数的引用。在你的代码中匿名函数:
function(err, usernameExists, emailExists){
if(err) throw err;
if(usernameExists){
return res.status(401).json({ err: "User exists"});
}
else if(emailExists){
return res.status(401).json({ err: "Email exists"});
}
res.status(200).json({status: "Succesful"});
})
应该在passport.authenticate
函数中作为callback
。像这样:
app.post("/api/register", function(req, res){
passport.authenticate("local-register", function(err, usernameExists, emailExists){
if(err) throw err;
if(usernameExists){
return res.status(401).json({ err: "User exists"});
}
else if(emailExists){
return res.status(401).json({ err: "Email exists"});
}
res.status(200).json({status: "Succesful"});
})(req, res);
});
另请注意,匿名函数的第二个参数应该是应用程序在有机会验证凭据(用户对象)后提供的对象,第三个参数是有关用户的其他信息。关于LocalStrategy中的代码,为了在参数中传递req
对象,您需要指定选项{passReqToCallback : true}
,之后在函数callback
中将有四个参数是req
,username
,password
和另一个callback
函数,通常名为done
,因此签名应该是这样的:
var registerStrategy = new localStrategy(
{passReqToCallback : true},
function(req, username, password, done){
...
}