未能结合 JWT 和 Passport 谷歌策略

问题描述

对于使用 jwt 令牌的普通登录 Nodejs 应用程序。我想将 jwt 令牌与护照谷歌和 Facebook 策略一起使用。我使用了以下方法,它给了我一个令牌,但是当我使用它访问受授权保护的 API 时,它不起作用。 我是 nodejs 新手,任何帮助或澄清都会很棒。

passport.use(
  new GoogleStrategy(
    {
      clientID:
        "-------------------------",clientSecret: "***********************",callbackURL: "************************",passReqToCallback: true,},function (request,accesstoken,refreshToken,profile,done) {
      console.log(profile);
      // generate auth token
      let userPayload = {
        firstname: profile.given_name,lastname: profile.family_name,googleId: profile.id,email: profile.email,};
      const token = jwt.sign(userPayload,process.env.SECRET,{
        expiresIn: 8640000000,//86400// 1 day
      });

      User.findOrCreate(
        { googleId: profile.id },{
          firstname: profile.given_name,function (err,user) {
          return done(err,user);
        }
      );

      console.log({ token });
    }
  )
);

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...