gpt4 book ai didi

express - 使用 Passport.js 显示 flash 消息

转载 作者:行者123 更新时间:2023-12-04 02:07:40 25 4
gpt4 key购买 nike

我在 Express 4 中使用 Passport.js 时无法显示即显消息。Passport.js 本地策略文档显示了如何设置即显消息,但没有太多关于如何实际显示它的内容。

这是我一直以来的做法。

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 未定义的信息。 console.log(flash) 什么也没显示。如何显示flash

最佳答案

是的,passport 关于其与 connect-flash 交互的文档肯定需要更新,因为它具有误导性(我不确定如何向他们提出建议)。

当您将带有消息的对象传递给策略的验证回调时,如下所示:return done(null, false, {message: "Wrong username/password"});Passport 实际上是在 connect-flash 中设置“错误”消息而不是“消息”消息——换句话说,passport 可能在后台执行此操作:req.flash('error', info.message) 其中信息是 {message: "Wrong username/password"}。因此,您应该使用 var flash = req.flash('error') 来检索消息。

注意:如果传递给本地策略的用户名或密码为空,passport 将在内部设置连接闪存中的“错误”消息和消息“缺少凭据”。因此,IMO,您最好在 connect-flash 的相同“错误”属性上设置消息,以使其与 Passport 的内置行为保持一致。但是,如果您想在本地策略中为“消息”等不同属性设置消息,您可以使用 connect-flash setter 显式设置它,如下所示:req.flash('message', yourMessage).

我发现这一点的方法是简单地记录 session 对象以查看 flash 对象及其在 Passport 身份验证后的所有消息,因为设置 flash 消息(使用 req.flash())也会创建一个 flash session 对象上的对象(假设您已经正确设置了 express 和 passport 的 session )。所以 console.log(req.session) 将向您显示 flash 对象及其包含的所有消息。

注意:一旦您像这样使用 getter 检索 flash 消息:req.flash('error'),flash 对象将从 session 对象中删除,因此请确保在检索闪存消息之前控制台记录 session 对象。

旁注:您可以根据需要设置任意数量的闪存“错误”消息,它只会将其附加到“错误”数组:

req.flash('error', 'Error #1')
req.flash('error', 'Error #2')
console.log(req.flash('error')) // returns ['Error #1', 'Error #2']

关于express - 使用 Passport.js 显示 flash 消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41869422/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com