使用PassportJS,如何将其他表单字段传递给本地身份验证策略?

k00*_*00k 85 authentication callback node.js express passport.js

我使用passportJS,我想提供的不仅仅是更多的req.body.usernamereq.body.password我的身份验证策略(护照本地).

我有3个表单字段:username,password,和foo

我如何req.body.foo从我的本地策略访问,如下所示:

passport.use(new LocalStrategy(
  {usernameField: 'email'},
    function(email, password, done) {
      User.findOne({ email: email }, function(err, user) {
        if (err) { return done(err); }
        if (!user) {
          return done(null, false, { message: 'Unknown user' });
        }
        if (password != 1212) {
          return done(null, false, { message: 'Invalid password' });
        }
        console.log('I just wanna see foo! ' + req.body.foo); // this fails!
        return done(null, user, aToken);

      });
    }
));
Run Code Online (Sandbox Code Playgroud)

我在我的路线(不是路线中间件)中调用这个,如下所示:

  app.post('/api/auth', function(req, res, next) {
    passport.authenticate('local', {session:false}, function(err, user, token_record) {
      if (err) { return next(err) }
      res.json({access_token:token_record.access_token});
   })(req, res, next);

  });
Run Code Online (Sandbox Code Playgroud)

Jar*_*son 166

passReqToCallback您可以启用一个选项,如下所示:

passport.use(new LocalStrategy(
  {usernameField: 'email', passReqToCallback: true},
  function(req, email, password, done) {
    // now you can check req.body.foo
  }
));
Run Code Online (Sandbox Code Playgroud)

何时,set req成为验证回调的第一个参数,您可以根据需要进行检查.

  • 这对于实施多租户/多租户身份验证非常有用,但在我的Google搜索中没有出现.希望我的评论能够帮助人们在将来找到答案. (9认同)
  • 这很有效,谢谢.指南中是`passReqToCallback`吗?我没有看到它. (7认同)
  • 还没.我在为指南添加新功能/选项方面落后了. (2认同)