未定义用户:Nodejs/Express + Passport



我的问题与这个问题非常相似,但是答案似乎对我不起作用(我看到用户也从未选择过答案)。

我有一个全新安装的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' });
});

最新更新