我的问题与这个问题非常相似,但是答案似乎对我不起作用(我看到用户也从未选择过答案)。
我有一个全新安装的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' }));
我正在使用快速会话。
我的 LocalStrategy、序列化和反序列化用户都被调用了,但坦率地说,我不太确定在这个测试应用程序上的反序列化功能上放什么。
有什么修复建议吗?
你会得到user is not defined
user
因为实际上没有在你的deserializeUser()
回调中定义。如果您查看本页"会话"部分中的示例,您会发现您应该在数据库中查找id
并将用户对象(从数据库查询结果生成)传递给done
回调。
出于简单的测试目的,您可以轻松地使用虚假的用户对象,直到您设置了数据库:
passport.deserializeUser(function(id, done) {
console.log('Deserialize user called.');
return done(null, { firstName: 'Foo', lastName: 'Bar' });
});