Eu tive um problema com o módulo Passport.js e o Express.js.
Este é o meu código e eu só quero usar um login codificado na primeira tentativa.
Eu sempre recebo a mensagem:
Pesquisei bastante e encontrei algumas postagens no stackoverflow, mas não obtive a falha.
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 fica assim.
'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');
}();
Obrigado.
node.js
express
login
passport.js
passport-local
user2244925
fonte
fonte
serializeUser
função armazena apenas o ID do usuário na sessão edeserializeUser
usa esse ID para recuperar os dados do usuário de um banco de dados (por exemplo). Isso evita que o armazenamento da sessão contenha os dados reais do usuário.Se você decidir não usar sessões, poderá definir a sessão como false
fonte
Parece que você perdeu uma parte da configuração do passportjs, especificamente esses dois métodos:
Eu adicionei um pouco sobre
._id
vs.,.id
mas esse trecho é da seção de configuração dos documentos, faça outra leitura e boa sorte :)fonte
Aqui, uma maneira prática, mas ainda preguiçosa, de usar sessões e ainda "serializar" os valores.
no caso de erros estranhos, pergunte a si mesmo: "Eu realmente defino '_id' no meu objeto de usuário?" - na maioria dos casos você não. Portanto, use um atributo apropriado como chave.
fonte
Usando o Promise com serializeUser e deserializeUser:
Consulte meu repositório do github para obter um exemplo de código completo de como resolver esse problema.
fonte
no passport.use ('local-login' ...) / ou / ('local-singup' ...)
se err você tem que retornar "false" err {return done (null, req.flash ('megsign', 'Nome de usuário já existe #! #'));} true {return done (null, false, req.flash (' megsign ',' Nome de usuário já existe #! # '));}
fonte