无法从Facebook护照中获取电子邮件信息

时间:2018-03-02 07:20:15

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

目前我正在开发一个项目来存储来自Facebook身份验证的信息,我已经检查了Passport-facebook doesn't get email以查看解决方案,这是我的代码

passport.use(new FacebookStrategy(
  {
    clientID: 'xxxxxxxxxxxxx',
    clientSecret: 'xxxxxxxxxxxxxxxx',
    callbackURL: 'http://1bc600b4.ngrok.io/auth/facebook/callback',
    profileFields: ['id', 'displayName', 'name', 'photos', 'email'],
  },
  (accessToken, refreshToken, profile, done) => {
    console.log(profile);
    models.User.findOne({ where: { facebookID: profile.id } }).then((existinguser) => {
      if (existinguser) {
        // Nothing will happen, the ID already exists
        done(null, existinguser);
      } else {
        models.User.create({
          // email: profile.emails[0].value,
          username: 'hello',
          firstname: profile.name.givenName,
          lastname: profile.name.familyName,
          facebookID: profile.id,
          avatar: `https://graph.facebook.com/${profile.id}/picture?redirect=true&height=470&width=470`,
          avatarThumb: profile.photos[0].value,
          last_login: Date.now(), }).then(user => done(null, user));
      }
    });
  },
));

app.use(passport.initialize());

app.get('/flogin', passport.authenticate(
  'facebook',
  passport.authenticate('facebook', { scope: ['profile', 'email'] }),
));

app.get(
  '/auth/facebook/callback',
  passport.authenticate('facebook', { session: false }),
  (req, res) => {
    res.send('AUTH WAS GOOD!');
  },
);

我不明白为什么我这样使用电子邮件信息仍然没有出现,这让我失去了很多信息,任何人都可以给我一个解决这个问题的暗示吗?谢谢!

1 个答案:

答案 0 :(得分:0)

此问题已存在一段时间,您需要包含电子邮件范围,即使这样,它也可能因用户隐私设置或用户的电子邮件未在Facebook端验证而发送Facebook电子邮件。

你可以添加这样的范围:

passport.use(
   new FacebookStrategy({
            clientID: 'CLIENT_ID',
            clientSecret: 'CLIENT_SECRET',
            callbackURL: "http://www.example.com/auth/facebook/callback"
            passReqToCallback : true,
            profileFields: ['emails'] // email should be in the scope.
   })
)

此外,您还需要将此添加到您的授权路线

app.get('/login/facebook', passport.authorize('facebook', { scope : ['email'] }));

如果电子邮件返回,它将是一个列表,您可以像这样访问它们:

1. profile.emails // [email1@example.com, somerandomdude@gmail.com]
2. profile.emails[1].value // randomdude@yahoo.com

如果它没有返回,您可以使用他们的用户名或ID并暂时创建一个Facebook电子邮件,如下所示:

username@facebook.com // this exists.