Nest通用工具函数执行顺序

本文介绍如何利用请求流程去记忆这些通用函数的执行顺序,解决不知道时候用通用函数的问题

通用工具函数执行流程

通用工具函数这里包括Middleware中间件、Exception filters异常过滤器、Pipes管道、Guards守卫、Interceptors拦截器

执行流程为中间件→守卫→拦截器→管道→拦截器→异常管理器

中间件

cors中间件为例,这是用于处理跨域的一个函数,代码如下:

ts 复制代码
consumer.apply(cors()).forRoutes(CatsController); // 文档代码

这是第一层关卡,如果存在跨域状况,那么后续的就直接不存在请求流程,所以中间件处在执行顺序的第一位

守卫

以用于划分权限路由守卫为例,如果不具备当前控制器所需要的权限,则无权执行路由,代码如下:

ts 复制代码
@@filename(cats.controller)
@Post()
@Roles(['admin'])
async create(@Body() createCatDto: CreateCatDto) {
  this.catsService.create(createCatDto);
}

也就是即使不存在跨域 问题,如果用户不具备某个权限,也无法执行请求流程,所以守卫排在第二位

拦截器

拦截器是比较特殊的,可用于在方法执行之前/之后绑定额外的逻辑,这一步已经处于请求执行过程 以文档中的代码为例:

ts 复制代码
@@filename(logging.interceptor)
import { Injectable, NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
import { Observable } from 'rxjs';
import { tap } from 'rxjs/operators';

@Injectable()
export class LoggingInterceptor implements NestInterceptor {
  intercept(context: ExecutionContext, next: CallHandler): Observable<any> {
    console.log('Before...');

    const now = Date.now();
    return next
      .handle()
      .pipe(
        tap(() => console.log(`After... ${Date.now() - now}ms`)),
      );
  }
}

在执行路由处理程序之前,会输出Before...,而在执行完后,将输出After... 1ms,这是通过rxjs操作流实现的,可见在请求之前和请求之后都可执行拦截器的逻辑

所以过了守卫之后,会遇到拦截器,排在执行顺序的第三位(或第五位)

管道

管道的作用是对请求的数据进行处理,例如将字符串类型转换为Int类型,便于数据处理,代码如下:

ts 复制代码
@Get(':id')
async findOne(@Param('id', ParseIntPipe) id: number) {
  return this.catsService.findOne(id);
}

所以这一阶段是位于请求之中 了(实际上处于进入路由但没进入路由处理程序的阶段),即拦截器请求之前的下一位,故处于请求流程的第四位

异常过滤器

异常过滤器主要用于抛出错误反馈给客户端,通常结合```try...catch``,代码如下:

ts 复制代码
@@filename(cats.controller)
@Get()
async findAll() {
  try {
    await this.service.findAll()
  } catch (error) {
    throw new HttpException({
      status: HttpStatus.FORBIDDEN,
      error: 'This is a custom message',
    }, HttpStatus.FORBIDDEN, {
      cause: error
    });
  }
}

反馈信息是请求的最后流程,所以异常过滤器是最后执行顺序的最后一步

相关推荐
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
葫芦和十三1 天前
图解 MongoDB 13|WiredTiger 存储引擎:B-tree、页和 checkpoint 三件套
后端·mongodb·agent
葫芦和十三1 天前
图解 MongoDB 14|Cache 与淘汰:WiredTiger 的内存治理
后端·mongodb·面试
IT_陈寒1 天前
Vue这个坑我跳了两次,原来问题出在这
前端·人工智能·后端
kyriewen1 天前
我用 50 行代码重写了 React Router 核心,终于搞懂了前端路由原理
前端·javascript·react.js
ServBay1 天前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队
后端·python
用户8356290780511 天前
如何使用 Python 添加和管理 Excel 批注(完整示例)
后端·python
用户8356290780511 天前
使用 Python 管理 Excel 工作表:创建、复制、删除与重命名
后端·python
lizhongxuan1 天前
Agent Tool
后端
悟空瞎说1 天前
NestJS 12 预览版重磅来袭:全面原生 ESM 正式落地
nestjs