用户未定义:Nodejs / Express + Passport

时间:2015-01-26 01:24:14

标签: node.js express passport.js

我的问题与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,序列化和反序列化用户都被调用了,但坦率地说,我不确定该测试应用程序上的反序列化函数应该放什么。

有关修复的任何建议吗?

1 个答案:

答案 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' });
});