nestjs使用jwt

开门见山

一、第一步

npm i @nestjs/jwt passport-jwt @types/passport-jwt

二、第二步

nest g mo jwtDemo
//新建模块
nest g s jwtDemo
//新建服务
nest g co jwtDemo

三、使用jwt

出于代码规范,我习惯将配置文件都写在config中使用时引入

config.ts

export const jwtKey = {
  secret: 'lgldl',
};

jwt-demo.module.ts

import { JwtStrategy } from './jwt.strategy';
import { Module } from '@nestjs/common';
import { JwtDemoService } from './jwt-demo.service';
import { JwtDemoController } from './jwt-demo.controller';
import {  JwtModule } from '@nestjs/jwt';
import {jwtKey} from './config'
@Module({
  imports: [
    JwtModule.register({
      //生成token的key
      secret:jwtKey.secret,
      // signOption可以在JwtModule设定
      // 或是在createToken时候设定
      signOptions: {
        //token的有效时长
          expiresIn: '1h',
      },
  }),
  ],
  providers: [JwtDemoService,JwtStrategy],
  controllers: [JwtDemoController]
})
export class JwtDemoModule {}

jwt.strategy.ts //用于验证token

import { Strategy, ExtractJwt } from 'passport-jwt';
import { Injectable } from '@nestjs/common';
import { PassportStrategy } from '@nestjs/passport';
import { jwtKey } from './config';
@Injectable()
export class JwtStrategy extends PassportStrategy(Strategy) {
  constructor() {
    super({
      jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
      ignoreExpiration: false,
      secretOrKey: jwtKey.secret,
    });
  }
    // Passport会自动verify jwt,如果key不正确,或是相关信息
  
  async validate(payload) {
      //payload与加密前的json对象一样
    //因为已经验证过token了所以在payload中进行验证用户信息是否为空
    if(!payload.username || !payload.password) {
      return false;
    }
    let user={ username: payload.username, password: payload.password };
    //返回后可在req中得到返回的值
    return user;
  }
}

jwt-demo.service.ts

import { JwtService } from '@nestjs/jwt';
import { Injectable, UnauthorizedException } from '@nestjs/common';
@Injectable()
export class JwtDemoService {
  constructor(
    // 注入UsersService,所以需要import UsersModule
    // 底下的provider才能被注入
    private readonly jwtService: JwtService,
  ) {}
   
  async createToken(user) {
    const payload = {username: user.name, password: user.password};
    //在实际项目中一般要进行数据库验证查看用户用户名密码是否正确
    //const data = await this.userRepository.findOne({username:user.username, password: user.password})
    //if(!data) {
     // return {code: 1 , msg:'登录失败', data: ''}
    //}
    delete user.password;
    return {
      msg:'登录成功',
      data: {
        user: user,
        //得到token
        token: this.jwtService.sign(payload)
      },
    };
  }
}

jwt-demo.control.ts

import { JwtDemoService } from './jwt-demo.service';
import { JwtService } from '@nestjs/jwt';
import { Controller, UseGuards, Get, Post, Req, Body } from '@nestjs/common';
import { AuthGuard } from '@nestjs/passport';
@Controller('')
export class JwtDemoController {
  JwtDemoService: any;
  constructor(private readonly jwtDemoService: JwtDemoService){}
  //使用jwt验证token的端口
  @UseGuards( AuthGuard('jwt'))
  @Post('tokenIn')
  aPost(@Req() req){
    return req.user;
  }
  @Post('getToken')
    getTokenByUserId(
            @Body() user: any,
    ){
      return this.jwtDemoService.createToken(user);
    }
}

OK

效果如下:

直接访问的话会这样

直接访问

获取token

获取token

在请求中设置token

设置token

进行请求

设置后进行请求

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
nestjs是一个基于Node.js的开发框架,它提供了一种简单而强大的方式来构建高效、可扩展的服务器端应用程序。而JWT(JSON Web Token)是一种用于身份验证和授权的开放标准,它可以在客户端和服务器之间安全地传输信息。 在nestjs使用JWT进行身份验证和授权非常简单。下面是使用nestjs中的jwt模块进行身份验证和授权的基本步骤: 1. 首先,安装`@nestjs/jwt`模块。可以使用npm或者yarn进行安装: ``` npm install --save @nestjs/jwt ``` 2. 在nestjs的模块中导入`JwtModule`并配置密钥和其他选项。在`app.module.ts`文件中添加以下代码: ```javascript import { Module } from '@nestjs/common'; import { JwtModule } from '@nestjs/jwt'; @Module({ imports: [ JwtModule.register({ secret: 'your-secret-key', // 密钥,用于签署和验证token signOptions: { expiresIn: '1h' }, // token的过期时间 }), ], }) export class AppModule {} ``` 3. 创建一个`AuthService`服务,用于生成和验证JWT。在`auth.service.ts`文件中添加以下代码: ```javascript import { Injectable } from '@nestjs/common'; import { JwtService } from '@nestjs/jwt'; @Injectable() export class AuthService { constructor(private readonly jwtService: JwtService) {} async generateToken(payload: any): Promise<string> { return this.jwtService.sign(payload); } async verifyToken(token: string): Promise<any> { return this.jwtService.verify(token); } } ``` 4. 在需要进行身份验证和授权的地方使用`AuthService`服务。例如,在一个控制器中,可以使用`@UseGuards`装饰器和`AuthGuard`守卫来保护路由。在`auth.controller.ts`文件中添加以下代码: ```javascript import { Controller, Post, UseGuards, Request } from '@nestjs/common'; import { AuthGuard } from '@nestjs/passport'; import { AuthService } from './auth.service'; @Controller('auth') export class AuthController { constructor(private readonly authService: AuthService) {} @Post('login') async login(@Request() req) { // 在这里进行用户身份验证,验证通过后生成token const token = await this.authService.generateToken({ username: req.body.username }); return { token }; } @Post('protected') @UseGuards(AuthGuard()) // 使用AuthGuard守卫保护路由 async protectedRoute() { // 在这里进行授权操作 return 'This route is protected'; } } ``` 这样,你就可以使用nestjsjwt模块进行身份验证和授权了。当用户登录成功后,会生成一个JWT token,并在后续请求中使用该token进行授权。 希望以上信息对你有帮助!如果你还有其他问题,请继续提问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值