認証が失敗した場合にフラッシュを送信する際に問題があります。すべてがOKであることを除いて。例 ( https://github.com/jaredhanson/connect-flash ) をアプリのフラッシュ メッセージにコピーすると、問題なく動作します...
これが私のコードです:
//routes
app.get('/login', function (req,res){
res.render('login', {
authMessage: req.flash('authMessage')
});
});
app.post('/login', passport.authenticate('local', {
failureRedirect: '/login',
failureFlash: true
}), function(req,res){
res.send('ok');
});
//local strategy
passport.use(new LocalStrategy(
function(username, password, authCheckDone) {
UserDetails.findOne({username : username}).then(
function(user){
if (!user) {
console.log('bad username');
return authCheckDone(null, false, {authMessage: 'Wrong name'});
}
if (user.password !== password) {
console.log('bad password');
return authCheckDone(null, false, {authMessage: 'Wrong password'});
}
return authCheckDone(null, user);
}),
function(error){
return authCheckDone(error);
};
}
));
//ejs
<% if (authMessage.length > 0) { %>
<p>test</p>
<%= authMessage %>
<% } %>
この問題はセキュリティに関連しており、https を使用していない可能性があることをどこかで読んだことがありますが、それが github の例である場合はどちらも機能しません...