我从未遇到过像这样令人烦恼的问题。似乎完全没有地方可以查找或者回答这个问题。我想做的就是获取护照(passport)以截取对"/login"和"/getloginStatus"的调用。
当登录时,我只想使用Json对象作为{username/password}的参数。当我登录后,如果用户在浏览器中具有身份验证票据,我只希望返回true/false。
以下是我的代码,但它根本不起作用,问题的一半似乎是我的本地策略实现从未被调用...
当登录时,我只想使用Json对象作为{username/password}的参数。当我登录后,如果用户在浏览器中具有身份验证票据,我只希望返回true/false。
以下是我的代码,但它根本不起作用,问题的一半似乎是我的本地策略实现从未被调用...
var passport = require('passport')
, LocalStrategy = require('passport-local').Strategy;
passport.use(new LocalStrategy(
function(username, password, done) {
console.log('this NEVER gets called');
}
));
app.post('/api/authentication/login', function(req, res, next) {
passport.authenticate('local', function(err, user, info) {
console.log('this does get called but so what?');
if (err) { return next(err); }
if (!user) { return res.redirect('/login'); }
req.logIn(user, function(err) {
console.log('this does get called but so what am I logged in?');
next();
});
})(req, res, next);
});
app.get('/api/authentication/getloginStatus', function(req, res, next) {
passport.authenticate('local', function(err, user, info) {
//what do I return here? !!!?
})(req, res, next);
});
非常感谢您提供的帮助!