Ошибка: не удалось сериализовать пользователя на сеанс

Привет, у вас возникла проблема с модулем паспорта и выражением.

Это мой код, и я просто хочу использовать жесткую регистрацию для первой попытки.

Я всегда получаю сообщение:

Я много искал и нашел несколько сообщений в 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');

}();

Ответ 1

Похоже, вы не реализовали passport.serializeUser и passport.deserializeUser. Попробуйте добавить это:

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

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

Ответ 2

Если вы решили не использовать сеансы, вы можете установить для сеанса значение false

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

Ответ 3

Похоже, вы пропустили часть паспортной установки, в частности, эти два метода:

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 vs. .id, но этот фрагмент из Конфигурирования раздела документов, дайте это другому чтению и удачи:)

Ответ 4

Здесь работает, но все еще ленивый способ использовать сеансы и все еще "сериализовывать" значения.

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 "в свой пользовательский объект?" - в большинстве случаев вы этого не делаете. Поэтому используйте правильный атрибут в качестве ключа.

Ответ 5

Использование Promise с serializeUser и deserializeUser:

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

passport.deserializeUser((id, done) => {
  // console.log(`id: ${id}`);
  User.findById(id)
    .then((user) => {
      done(null, user);
    })
    .catch((error) => {
      console.log(`Error: ${error}`);
    });
});

Пожалуйста, см. мой github repo для полного примера кода, как решить эту проблему.