FacebookTokenError:此授权码已被使用passport-js

时间:2019-06-07 16:52:13

标签: node.js express passport.js facebook-login

我已经使用passport.js实现了log in with facebook。但是有时候,每当我尝试登录时,都会出现此错误-

FacebookTokenError: This authorisation code has been used

但是事实是它太随机了。有时它完美地工作。有时会出现此错误。我已经尝试了SO帖子中提供的所有解决方案。它们都不起作用。

我使用react作为我的前端,使用node.js作为后端。对于使用express-session的会话中间件。

这是我用来实现log in with facebook

的代码
import passport from 'passport';
import { Strategy } from 'passport-facebook';

const { FACEBOOK_APP_ID, FACEBOOK_APP_SECRET, API_URL } = process.env;

export default (app) => {
  app.use(passport.initialize());
  app.use(passport.session());

  passport.serializeUser((user, cb) => cb(null, user));
  passport.deserializeUser((obj, cb) => cb(null, obj));

  passport.use(new Strategy({
    clientID: FACEBOOK_APP_ID,
    clientSecret: FACEBOOK_APP_SECRET,
    callbackURL: `${API_URL}facebook/callback`,
    profileFields: ['id', 'displayName', 'email', 'name', 'photos'],
    passReqToCallback: true,
    enableProof: true,

  }, async (req, accessToken, refreshToken, profile, cb) => {
    try {
      const email = (profile.emails && profile.emails[0].value) || '';
      const { displayName } = profile;
      const users = await Users.findOrCreate({
        where: { email },
        defaults: { name: displayName },
      }).catch((err) => {
        console.log(err);
      });
      if (users.length) {
        req.session.userId = users[0].get('id');
        return cb(null, users[0]);
      }
    } catch (err) {
      console.log('error during fb: ', err);
    }
    return cb('error in facebook');
  }));

  app.use('/facebook', passport.authenticate('facebook', { session: false, scope: ['public_profile', 'email'] }));

  app.use('/facebook/callback', passport.authenticate('facebook', { session: false, failureRedirect: `${FRONTEND_HOST}` }), (_, res) => {
    res.redirect(`${FRONTEND_HOST}`);
  });
};

这是我得到的完整错误-

two muppets

1 个答案:

答案 0 :(得分:1)

我不确定您的代码的实际问题,但您需要使用:

(?<=^|\s)@(?=[^\W\d]\w{0,47}\b)

代替

app.get('/facebook', ...)
app.get('/facebook/callback', ...)