首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用passport-jwt获取当前登录用户

如何使用passport-jwt获取当前登录用户
EN

Stack Overflow用户
提问于 2020-12-15 23:59:23
回答 1查看 30关注 0票数 0

我实现了passport-jwt来验证受保护路由上的用户,我还想在创建第一个管理员之前检查可能的用户登录,请帮助我如何做。这是我实现的passport-jwt代码

代码语言:javascript
复制
exports.getToken = function (user) {
  return jwt.sign(user, config.secretKey, { expiresIn: 3600 });
};

var opts = {};
opts.jwtFromRequest = ExtractJwt.fromAuthHeaderAsBearerToken();
opts.secretOrKey = config.secretKey;

exports.jwtPassport = passport.use(
  new JwtStrategy(opts, (jwt_payload, done) => {
    console.log("JWT payload: ", jwt_payload);
    User.findOne({ _id: jwt_payload._id,  }, (err, user) => {
      if (err) {
        return done(err, false);
      } else if (user) {
        return done(null, user);
      } else {
        return done(null, false);
      }
    });
  })
);
EN

回答 1

Stack Overflow用户

发布于 2020-12-16 22:50:27

如果我正确理解了您的问题,您已经对用户进行了身份验证,并且该用户已登录。现在,在创建管理员之前,您需要检查当前登录的用户是否未过期或其他情况。对吧?

为此,请执行以下操作:

JWT您需要将存储在客户端,以便无论何时调用

  1. ,都可以将JWT附加到请求的身份验证头中。我之所以说身份验证头,是因为您的ExtractJWT策略是fromAuthHeaderAsBearerToken.

使用此选项,您可以将令牌附加到后续

  1. 标头。您还需要在服务器端实现一个中间件,以便控制器可以验证Authorization中的JWT是有效还是无效。

Here是理解管道的一个很好的资源。请注意,在此资源中,他们将fromUrlQueryParameter作为提取策略,但概念是相同的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65309394

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档