Express 使用Passport.js显示flash消息
在Express 4中使用Passport.js时,我无法显示flash消息。js local strategy文档显示了如何设置flash消息,但没有太多关于如何实际显示它的内容 我就是这样做的Express 使用Passport.js显示flash消息,express,passport.js,connect-flash,Express,Passport.js,Connect Flash,在Express 4中使用Passport.js时,我无法显示flash消息。js local strategy文档显示了如何设置flash消息,但没有太多关于如何实际显示它的内容 我就是这样做的 passport.use(new auth(function (username, password, done) { con.query(query.login, [username], function(err, rows) { if (err) {
passport.use(new auth(function (username, password, done) {
con.query(query.login, [username], function(err, rows) {
if (err) {
done(err);
}
if (rows.length != 1) {
console.log('Login attempted for ' + username);
return done(null, false, {message: "Wrong username/password"});
}
user = rows[0];
bcrypt.compare(password, user.passwordHash, function (err, correct) {
delete user.passwordHash;
if (correct) {
return done(null, user);
} else {
console.log('Login attempted for ' + username);
return done(null, false, {message: "Wrong username/password"});
}
})
});
}));
app.get('/login', function(req, res) {
var pageParameters = {};
var flash = req.flash('message');
// console.log(flash);
if (flash != null && flash != '') {
pageParameters.message = flash;
}
res.render('login', pageParameters);
});
app.post('/login', passport.authenticate('local', {
failureRedirect: '/login',
failureFlash: true
}), function (req, res) {
req.session.user = req.user;
if (typeof req.session.redirect !== 'undefined') {
res.redirect(req.session.redirect);
delete req.session.redirect;
} else {
res.redirect('/');
}
});
没有错误,控制台没有告诉我任何关于flash
未定义的信息<代码>控制台日志(闪存)不显示任何内容。如何显示flash
?工作项目请参见
是的,passport关于它与connect flash交互的文档肯定需要更新,因为它具有误导性(我不知道如何向他们提出建议) 将带有消息的对象传递给策略的verify回调时,如下所示:
返回完成(null,false,{消息:“错误的用户名/密码”})代码>
Passport实际上是在connect flash中设置“错误”消息而不是“消息”消息-换句话说,Passport可能在后台执行此操作:req.flash('error',info.message)
其中信息是{message:“错误的用户名/密码”}
。因此,您应该执行var flash=req.flash('error')
来检索消息
注意:如果传递给本地策略的用户名或密码为空,passport将在connect flash中内部设置“错误”消息,并显示消息“缺少凭据”。因此,在我看来,您最好也在connect flash的相同“错误”属性上设置消息,以使其与passport的内置行为保持一致。
但是,如果您想在本地策略中的不同属性(如“message”)上设置消息,可以使用connect flash setter显式设置它,如:req.flash('message',yourMessage)
我发现这一点的原因只是简单地记录会话对象,以便在passport身份验证后查看flash对象及其所有消息,因为设置flash消息(使用req.flash()
)也会在会话对象上创建一个flash对象(假设您使用express和passport正确设置了会话)。因此console.log(req.session)
将向您显示flash对象及其包含的所有消息
注意:一旦使用getter检索flash消息,如:req.flash('error')
,flash对象将从会话对象中删除,因此在检索flash消息之前,请确保控制台记录会话对象
旁注:您可以根据需要设置任意数量的flash“错误”消息,它只会将其附加到“错误”数组中:
req.flash('error', 'Error #1')
req.flash('error', 'Error #2')
console.log(req.flash('error')) // returns ['Error #1', 'Error #2']
我在这里找到了一个解决方案:
req.flash('error', 'Error #1')
req.flash('error', 'Error #2')
console.log(req.flash('error')) // returns ['Error #1', 'Error #2']