Erro: falha ao serializar usuário em sessão

votos
109

oi tem um problema com o módulo de passaporte e expresso.

Este é o meu código e eu só quero usar um login codificado para a primeira tentativa.

Eu sempre recebo a mensagem:

Eu procurei muito e encontrei alguns posts em stackoverflow, mas eu não obter o fracasso.

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

Meu código se parece com isso.

'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');

}();
Publicado 13/11/2013 em 09:26
fonte usuário
Em outras línguas...                            


6 respostas

votos
232

Parece que você não implementar passport.serializeUsere passport.deserializeUser. Tente adicionar o seguinte:

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

passport.deserializeUser(function(user, done) {
  done(null, user);
});
Respondeu 13/11/2013 em 10:07
fonte usuário

votos
23

Se você decidir não usar sessões, você pode definir a sessão para false

app.post('/login', passport.authenticate('local', {
  successRedirect: '/accessed',
  failureRedirect: '/access',
  session: false
}));
Respondeu 27/01/2016 em 05:12
fonte usuário

votos
12

Parece que você perdeu uma parte da configuração passportjs, especificamente estes dois métodos:

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);
  });
});

Eu adicionei o pouco sobre ._idvs. .idmas esse trecho é do Configurar Seção de docs, dar essa outra leitura e boa sorte :)

Respondeu 20/08/2015 em 01:41
fonte usuário

votos
1

Aqui um trabalho, mas ainda muito preguiçoso para usar sessões e ainda "serialisize" os valores.

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]);
});

no caso ou erros estranhos pergunte a si mesmo: "Eu rlly set '_id' no meu objeto de usuário?" - na maioria dos casos você não. Portanto, use um atributo adequado como chave.

Respondeu 20/02/2017 em 13:21
fonte usuário

votos
0

Usando Promise com 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}`);
    });
});

Por favor, veja o meu github repo para um exemplo de código completo como resolver esta questão.

Respondeu 31/07/2017 em 09:31
fonte usuário

votos
-1

em passport.use ( 'local-login' ...) / ou / ( 'local-singup' ...)

se err você tem que voltar "false" err {return feito (null, req.flash ( 'megsign', 'Nome de usuário já existe # #!'));} verdade {return feito (null, falsa, req.flash (' megsign', 'Nome de usuário já existe # #'));!}

Respondeu 09/11/2018 em 07:54
fonte usuário

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more