我的问题与this question非常相似,但答案似乎对我不起作用(我看到用户也从未选择过答案)。
我全新安装了Nodejs和Express。
我的设置:
app.use(express.static(path.join(__dirname, 'public')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser('hithere'));
app.use(session({
secret: 'hithere',
resave: false,
saveUninitialized: true
}));
app.use(passport.initialize());
app.use(passport.session());
passport.serializeUser(function(user, done) {
console.log('Serialize user called.');
return done(null, user);
});
passport.deserializeUser(function(id, done) {
console.log('Deserialize user called.');
return done(null, user);
});
passport.use(new LocalStrategy(
function(username, password, done) {
console.log('local strategy called with: %s', username);
return done(null, {username:username, password:password});
}));
app.use('/', routes);
app.use('/users', users);
app.get('/success', function(req, res) {
req.send('sucess!');
});
app.get('/failure', function(req, res) {
req.send('failure!');
})
app.post('/register', function(req, res) {
console.log(req.body);
});
app.post('/signup', passport.authenticate('local', { successRedirect: '/success', failureRedirect: '/failure' }));
我正在使用express-session。
我的LocalStrategy,序列化和反序列化用户都被调用了,但坦率地说,我不确定该测试应用程序上的反序列化函数应该放什么。
有关修复的任何建议吗?
答案 0 :(得分:4)
您获得user is not defined
因为user
实际上未在deserializeUser()
回调中定义。如果您查看this page上“会话”部分中的示例,您将看到您应该在数据库中查找id
并传递用户对象(根据数据库查询的结果生成) )done
回调。
出于简单的测试目的,您可以轻松地使用虚假的用户对象,直到您设置了数据库:
passport.deserializeUser(function(id, done) {
console.log('Deserialize user called.');
return done(null, { firstName: 'Foo', lastName: 'Bar' });
});