首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用nestjs身份验证时身份验证失败

使用nestjs身份验证时身份验证失败
EN

Stack Overflow用户
提问于 2018-05-23 12:54:19
回答 2查看 1.6K关注 0票数 0

我正在尝试使用nestjs文档实现身份验证。https://docs.nestjs.com/techniques/authentication

我正在实现JWT身份验证,在尝试访问经过身份验证的API时,即使在验证之前,我也会得到验证错误。有没有人遇到过类似的问题。

代码语言:javascript
运行
复制
@Get()
  @UseGuards(AuthGuard('jwt'))
  async findAll(): Promise<UserDto[]> {
    return this.userService.findAll();
  }

这条路给了我UnAuthorized错误。我对打字稿和网易都很陌生。

我的代码可以在我的GitHub回购中获得。请告诉我出了什么问题。Project/blob/master/src/user/user.controller.ts#L23

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-05-24 16:10:06

您的-轻微但关键的错误驻留在用于签名令牌的secretOrKey值中。在src/auth/jwt.strategy.tssrc/auth/auth.service.ts.之间有不同的值

src/auth/auth.service.ts

而不是这样:

代码语言:javascript
运行
复制
async createToken() {
    const user: UserDto = { name: 'shamnad', phoneNumber: '12435' };
    return jwt.sign(user, 'secretkey'); // <== /!\ focus on this one /!\
}

用这个:

代码语言:javascript
运行
复制
async createToken() {
        const user: UserDto = { name: 'shamnad', phoneNumber: '12435' };
        return jwt.sign(user, 'secretKey'); // <== /!\ focus on this one /!\
}

因为您使用secretKey来签名您的令牌,而不是secretkey (注意骆驼的情况):

代码语言:javascript
运行
复制
constructor(private readonly authService: AuthService) {
    super({
      jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
      secretOrKey: 'secretKey', // <== /!\ focus on this line /!\
    });
}

为了避免此类问题,我建议您使用process.env.<your-variable>,而不是直接在字符串中手动设置配置。

src/auth/jwt.strategy.ts中应该是这样的:

代码语言:javascript
运行
复制
constructor(private readonly authService: AuthService) {
    super({
      jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
      secretOrKey: process.env.SECRET
    });
}

src/auth/auth.service.ts中,就像这样:

代码语言:javascript
运行
复制
async createToken() {
    const user: UserDto = { name: 'shamnad', phoneNumber: '12435' };
    return jwt.sign(user, process.env.SECRET); // <== /!\ focus on this one /!\
}

最后,要设置环境变量,请根据您的操作系统执行以下命令:

  • Mac:export SECRET=<your-secret-key>
  • Windows:set SECRET=<your-secret-key>

我希望它有帮助;)

票数 2
EN

Stack Overflow用户

发布于 2018-05-24 02:59:52

你是怎么进入这条路线的?

您必须先创建令牌。

不知道这是否给了你一个提示

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

https://stackoverflow.com/questions/50488975

复制
相关文章

相似问题

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