nestjs - 03

Nestjs 守卫(guard)

一、局部守卫
1、controller级守卫

生成guard.ts

nest g gu role
// role.guard.ts
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
import { Observable } from 'rxjs';

@Injectable()
export class RoleGuard implements CanActivate {
  canActivate(
    context: ExecutionContext,
  ): boolean | Promise<boolean> | Observable<boolean> {
    console.log('经过了守卫');
    return true;
  }
}

配置controller

// guard.controller.ts
import { Controller, UseGuards, Get } from '@nestjs/common'
import { RoleGuard } from './role.guard'

@Controller()
@UseGuards(RoleGuard)
export class GuardController {
  @Get()
  guardTest() {
    return 'guard test'
  }
}

2、智能守卫
// controller
import { Controller, UseGuards, Get, SetMetadata } from '@nestjs/common'
import { RoleGuard } from './role.guard'

@Controller()
@UseGuards(RoleGuard)
export class GuardController {
  @Get()
  @SetMetadata('role', ['admin']) //  两个参数可自定义,(key, value), 可以用key, value 做后期的判断逻辑
  metaGuardTest() {
    return 'meta guard test'
  }
}
// guard.ts
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
import { Observable } from 'rxjs';
import { Reflector } from '@nestjs/core'
import type { Request } from 'express'

@Injectable()
export class RoleGuard implements CanActivate {
  constructor(private reflector: Reflector)
  canActivate(
    context: ExecutionContext,
  ): boolean | Promise<boolean> | Observable<boolean> {
    const admin = this.reflector.get<string[]>('role'/* 此key 值为SetMetadata中定义的key值 */, contest.getHandler())
		const req = context.switchToHttp().getRequest<Request>()
    console.log('经过了守卫', admin, req);
    // 做权限验证,如果有就过
    if (admin.includes(req.query.role as string)) {
      return true
    } else {
      return false
    }
  }
}

三、全局守卫
import { RoleGuard } from './role.guard'

app.useGlobalGuards(new RoleGuard())
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值