我正在尝试使用passport.js和本地护照进行基本的用户名/密码验证。
虽然failureRedirect完全按照预期执行的操作(重定向到指定的页面),但successRedirect会对其指定页面的请求保持挂起状态,并在一段时间后返回“空响应”。
http://www.deviantpics.com/VdG
正如您在此图片中所看到的那样,当它请求仪表板时,它表示它的大小为0B,但当我继续使用该仪表板而没有重定向时,它表示它有1.6B。
我已经遍布Stackoverflow了,我找不到能帮到我的答案。
请你在我疯狂之前检查我的代码并提出一些建议。
这是护照加载代码
110011
routes.js
module.exports = function(app){
//set expression
var expressSession = require('express-session');
app.use(expressSession({
secret: credentials.session.secret
}));
//set passport
var passport = require('passport');
var localStrategy = require('./strategies/auth/local.js');
passport.use('local', localStrategy);
passport.serializeUser(function(user, done) {
done(null, user.id);
});
passport.deserializeUser(function(id, done) {
User.findById(id, function(err, user) {
done(err, user);
});
});
app.use(passport.initialize());
app.use(passport.session());
登录功能
//main
app.get('/', main.home);
app.get('/login', main.login);
app.get('/signup', main.signup);
app.post('/login', auth.loginLocal);
app.post('/signup', main.checkSignup);
//user
app.get('/user/dashboard', user.dashboard);
app.get('/user/addmemory', user.addMemory);
app.get('/user/memory', user.memory);
本地策略
exports.loginLocal = passport.authenticate('local', {
successRedirect: '/user/dashboard',
failureRedirect: '/login'
});
仪表板功能
var localAuthStrategy = new LocalStrategy(function(username, password, done) {
User.findOne({
username: username
}, function(err, user) {
if (err) {
return done(err);
}
if (!user) {
return done(null, false, {
message: 'Incorrect username'
});
}
if (!user.validPassword(password)) {
return done(null, false, {
message: 'Incorrect password'
});
}
return done(null, user);
});
});
答案 0 :(得分:5)
我找到了一个问题的答案,问题是用户模型没有在定义了serializeUser和deserializeUser的脚本中定义。 我无法弄清楚发生了什么,因为我没有在catch all handler中定义任何动作,所以要记住,确保捕获所有处理程序以确定发生了什么
app.use(function(err, req, res, next) {
console.log(err);
});
答案 1 :(得分:0)
几天前我遇到了同样的问题,发现我忘记在serializeUser
和deserializeUser
函数的末尾加上括号。
我实际上是将passport-local-mongoose
包用于各个功能。但是必须注意,在app.use()
中为所有模板文件调用并执行了函数,因此,我们确实在函数名称中使用了括号。