未定义用户:Nodejs/Express + 护照

user is not defined: Nodejs/Express + Passport

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

有任何修复建议吗?

你得到 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' });
});