我有一个护照.js模块和Express.js的问题。

这是我的代码,我只是想使用硬编码的登录第一次尝试。

我总是得到这样的信息:

我搜索了很多,在stackoverflow中找到了一些帖子,但我没有得到失败。

Error: failed to serialize user into session
    at pass (c:\Development\private\aortmann\bootstrap_blog\node_modules\passport\lib\passport\index.js:275:19)

我的代码是这样的。

'use strict';

var express = require('express');
var path = require('path');
var fs = require('fs');
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
var nodemailer = require('nodemailer');

var app = express();

module.exports = function setupBlog(mailTransport, database){
var config = JSON.parse(fs.readFileSync('./blog.config'));

app.set('view options', {layout: false});

app.use(express.static(path.join(__dirname, '../', 'resources', 'html')));


app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({ secret: 'secret' }));
app.use(passport.initialize());
app.use(passport.session());


app.get('/blog/:blogTitle', function(req, res) {
  var blogTitle = req.params.blogTitle;
  if(blogTitle === 'newest'){
    database.getLatestBlogPost(function(post) {
      res.send(post);
    });
  } else {
    database.getBlogPostByTitle(blogTitle, function(blogPost) {
      res.send(blogPost);
    });
  }
});

passport.use(new LocalStrategy(function(username, password, done) {
  // database.login(username, password, done);
  if (username === 'admin' && password === 'admin') {
    console.log('in');
    done(null, { username: username });
  } else {
    done(null, false);
  }
}));

app.post('/login', passport.authenticate('local', {
  successRedirect: '/accessed',
  failureRedirect: '/access'
}));





app.listen(8080);
console.log('Blog is running on port 8080');

}();

谢谢。


当前回答

听起来好像你错过了passportjs设置的一部分,特别是这两个方法:

passport.serializeUser(function(user, done) {
    done(null, user._id);
    // if you use Model.id as your idAttribute maybe you'd want
    // done(null, user.id);
});

passport.deserializeUser(function(id, done) {
  User.findById(id, function(err, user) {
    done(err, user);
  });
});

我添加了关于._id和.id的部分,但这个片段来自文档的配置部分,再读一遍,祝你好运:)

其他回答

这里有一种有效但仍然懒惰的使用会话并仍然“序列化”值的方法。

var user_cache = {};

passport.serializeUser(function(user, next) {
  let id = user._id;
  user_cache[id] = user;
  next(null, id);
});

passport.deserializeUser(function(id, next) {
  next(null, user_cache[id]);
});

以防出现奇怪的错误,只需问问自己:“我是否在我的用户对象中设置'_id' ?”-在大多数情况下你不会。所以使用合适的属性作为键。

看起来你没有执行护照。serializeUser和passport.deserializeUser。试着加上这个:

passport.serializeUser(function(user, done) {
  done(null, user);
});

passport.deserializeUser(function(user, done) {
  done(null, user);
});

在passport.use(“本地登录”…)/或/(“local-singup”…)

如果出错,就必须返回"false" Err{返回done(null, req。flash('megsign', '用户名已经存在#!#');} True{返回done(null, false, req。flash('megsign', '用户名已经存在#!#');}

你错过了这段代码:

passport.serializeUser(function(user, done) {
  done(null, user.id);
});

passport.deserializeUser(function(id, done) {
  User.findById(id, function(err, user) {
    done(err, user);
  });
});

具体请参见http://www.passportjs.org/docs/configure/中的会话部分

今天我发现另一个普遍的原因是,如果你使用标准的包,如护照,passport-local, passport-local-mongoose express-session和你已经登录的会话你然后你终止并重新启动服务器,您将在同一个会话登录浏览器保持加载没有响应,得到这个错误的用户会话”“失败的序列化。