使用passport.js进行Twitter身份验证

时间:2017-11-19 21:05:09

标签: javascript node.js twitter twitter-oauth passport.js

这是关于Twitter OAuth与passport.js()

的真正利基问题

我有一个控制器,使用他们的Twitter“头像”更新用户的头像:

const signInViaTwitter = (twitterProfile) => {
  return new Promise((resolve, reject) => {

    console.log(twitterProfile);

    // find if user exist on in
    User.findOne({ username: twitterProfile.username }, (error, user) => {
      if (error) { console.log(error); reject(error); }
      else {

        // user existed on db
        if (user) {
          // update the user with latest git profile info
          user.name = twitterProfile.displayName;
          user.username = twitterProfile.username;
          user.avatarUrl = twitterProfile.photos.value;
          user.email = '';

          // save the info and resolve the user doc
          user.save((error) => {
            if (error) { console.log(error); reject(error); }
            else { resolve(user); }
          });
        }

        // user doesn't exists on db
        else {
          // check if it is the first user (Adam/Eve) :-p
          // assign him/her as the admin
          User.count({}, (err, count) => {
            console.log('usercount: ' + count);

            let assignAdmin = false;
            if (count === 0) assignAdmin = true;

            // create a new user
            const newUser = new User({
              name: twitterProfile.displayName,
              username: twitterProfile.username,
              avatarUrl: twitterProfile.photos.value,
              email: '',
              role: assignAdmin ? 'admin' : 'user',
            });

            // save the user and resolve the user doc
            newUser.save((error) => {
              if (error) { console.log(error); reject(error); }
              else { resolve(newUser); }
            });

          });
        }
      }
    });
  });
};

用户的身份验证有效 - 但由于某种原因,头像将无法显示...以下是控制台输出:

  

拒绝加载图片“https://api.twitter.com/favicon.ico”   因为它违反了以下内容安全策略指令:   “img-src https://abs.twimg.com https://*.twimg.com   https://pbs.twimg.com数据:“。

有谁知道这意味着什么?我在想它可能是因为处于开发模式 - 也就是http://localhost:8080/ ......它不接受https?或者不会传回去?

更新:^我认为上述错误与图片无法显示无关...

稍微查看html源代码:

<img class="styles__userAvatar___2x2U9" src="{unknown}" alt="Wind Up Lord Vexxos Avatar">

所以它显然传递了src的未知变量 - 而不是用户的显示头像......

所以,对我来说,看起来违规行是:

user.avatarUrl = twitterProfile.photos.value;

我该怎么做呢?

1 个答案:

答案 0 :(得分:1)

只是一个想法,不是twitterProfile.photos一个数组?可能你应该尝试访问twitterProfile.photos [0] .value