我遇到了Passport.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');
}();
感谢。
答案 0 :(得分:301)
看起来您没有实施passport.serializeUser
和passport.deserializeUser
。尝试添加:
passport.serializeUser(function(user, done) {
done(null, user);
});
passport.deserializeUser(function(user, done) {
done(null, user);
});
答案 1 :(得分:36)
如果您决定不使用会话,则可以将会话设置为false
app.post('/login', passport.authenticate('local', {
successRedirect: '/accessed',
failureRedirect: '/access',
session: false
}));
答案 2 :(得分:15)
听起来你错过了passportjs设置的一部分,特别是这两种方法:
view
我添加了关于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
的内容,但是此代码段来自Configure Section个文档,请另外阅读并祝您好运:)
答案 3 :(得分:2)
这是一种工作但仍然懒惰的方式来使用会话并仍然“序列化”值。
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'?” - 在大多数情况下你不要。因此,请使用适当的属性作为密钥。
答案 4 :(得分:1)
将此代码用于您的 server.js 文件中,您可以在其中发出获取或发布请求。
app.get('/auth/facebook/callback',passport.authenticate('facebook',{
successRedirect:'/profile',
failureRdirect:'/',
session: false
}))
答案 5 :(得分:1)
确保在获取用户数据时使用了 async 和 await。
passport.serializeUser((user, done) => {
done(null, user.id);
});
passport.deserializeUser(async (id, done) => {
const USER = await User.findById(id);
done(null, USER);
});
passport.use(
new GoogleStrategy(
{
// options for google strategy
clientID: keys.google.clientID,
clientSecret: keys.google.clientSecret,
callbackURL: "/auth/google/redirect",
},
async (accessToken, refreshToken, profile, done) => {
// passport callback function
// check if user already exist in our db
const oldUser = await User.findOne({ googleId: profile.id });
if (oldUser) {
return done(null, oldUser);
} else {
const newUser = await new User({
username: profile.displayName,
googleId: profile.id,
}).save();
return done(null, newUser);
}
}
)
);
答案 6 :(得分:0)
使用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以获取完整的代码示例,了解如何解决此问题。
答案 7 :(得分:0)
您错过了这段代码:
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/中的会话部分
答案 8 :(得分:-1)
在password.use('local-login'...)/或/('local-singup'...)
如果出错,您必须返回“ false” 错误{返回完成(null,req.flash('megsign','用户名已存在#!#'));} true {返回完成(null,false,req.flash('megsign','用户名已存在#!#'));}