当前位置: 首页 > news >正文

NestJS 系列教程(四):中间件、中断器与异常过滤器详解

🔄 NestJS 系列教程(四):中间件、中断器与异常过滤器详解

✨ 本篇目标

你将学会:

  • 什么是中间件(Middleware),如何拦截请求
  • 什么是异常过滤器(Exception Filters),如何统一处理错误
  • Nest 中的请求生命周期是怎样的
  • 编写全局/模块级中间件与异常处理器

🚦 1. 中间件(Middleware)

什么是中间件?

中间件是一个在请求到达处理函数之前被调用的函数。你可以用它来记录日志、验证请求、添加请求数据等。

中间件的特征:

  • 类似 Express 的中间件函数 (req, res, next)
  • 可以访问请求与响应对象
  • 必须手动调用 next() 才会进入下一个处理阶段

🛠️ 编写中间件

示例:日志中间件 logger.middleware.ts

src/common/middleware/logger.middleware.ts 文件中创建:

import { Injectable, NestMiddleware } from '@nestjs/common';
import { Request, Response, NextFunction } from 'express';@Injectable()
export class LoggerMiddleware implements NestMiddleware {use(req: Request, res: Response, next: NextFunction) {console.log(`[Request] ${req.method} ${req.originalUrl}`);next();}
}

🔧 应用中间件(模块级注册)

cats.module.ts 中添加:

import { Module, NestModule, MiddlewareConsumer } from '@nestjs/common';
import { CatsController } from './cats.controller';
import { CatsService } from './cats.service';
import { LoggerMiddleware } from '../common/middleware/logger.middleware';@Module({controllers: [CatsController],providers: [CatsService],
})
export class CatsModule implements NestModule {configure(consumer: MiddlewareConsumer) {consumer.apply(LoggerMiddleware).forRoutes('cats'); // 仅拦截 /cats 路由}
}

可以通过 .forRoutes() 控制中间件作用范围,如所有 GET 路由、指定控制器、指定路径等。


🧨 2. 异常过滤器(Exception Filters)

默认行为

Nest 默认抛出的异常会被自动转化为 JSON 格式:

{"statusCode": 400,"message": "some error","error": "Bad Request"
}

但你可以创建自定义异常处理逻辑。


编写自定义异常过滤器

创建 common/filters/http-exception.filter.ts

import {ExceptionFilter,Catch,ArgumentsHost,HttpException,
} from '@nestjs/common';
import { Request, Response } from 'express';@Catch(HttpException)
export class HttpExceptionFilter implements ExceptionFilter {catch(exception: HttpException, host: ArgumentsHost) {const ctx = host.switchToHttp();const response = ctx.getResponse<Response>();const request = ctx.getRequest<Request>();const status = exception.getStatus();const errorResponse = {success: false,timestamp: new Date().toISOString(),path: request.url,message: exception.message,};response.status(status).json(errorResponse);}
}

✍️ 应用异常过滤器

方法级

@Post()
@UseFilters(HttpExceptionFilter)
create(@Body() dto: CreateCatDto) {throw new BadRequestException('手动抛出异常示例');
}

控制器级

@UseFilters(HttpExceptionFilter)
@Controller('cats')
export class CatsController {}

全局注册(推荐)

main.ts 中添加:

import { HttpExceptionFilter } from './common/filters/http-exception.filter';async function bootstrap() {const app = await NestFactory.create(AppModule);app.useGlobalFilters(new HttpExceptionFilter());await app.listen(3000);
}

🔁 3. Nest 请求生命周期简图

一个请求在 Nest 应用中经历以下流程:

客户端请求↓
中间件 (Middleware)↓
守卫 (Guards)↓
拦截器 (Interceptors)↓
管道 (Pipes)↓
控制器方法 (Controller)↓
服务 (Service)↑
异常过滤器 (ExceptionFilter)(如有异常)↑
响应客户端

本章主要关注中间件与异常过滤器,后续我们将逐步引入守卫、拦截器、管道的深入使用。


✅ 本篇小结

本章我们学习了:

  • 如何编写并应用 Nest 的中间件(Logger)
  • 理解并实现异常过滤器(统一错误响应格式)
  • 掌握 Nest 请求生命周期的关键阶段

🔮 下一篇预告

第5篇:守卫(Guards)与认证逻辑实现(基于角色与 JWT)

下一篇将介绍如何使用 Guards 实现路由级权限控制、角色限制、以及 JWT 用户验证机制。

http://www.dtcms.com/a/270051.html

相关文章:

  • JavaScript基础篇——第一章 JavaScript基础的认识
  • MySQL 【环境安装、基础认识】
  • OpenCV在Visual Studio 2022下的配置
  • 牛市来临之际,如何用期权抢占反弹先机?
  • Centos和麒麟系统如何每天晚上2点10分定时备份达梦数据库
  • VUE 带有搜索功能的穿梭框(简单demo)
  • 【DOCKER】-2 docker基础
  • 科技云报到:云智融合双buff,AI已开挂
  • 数据结构-顺序表-拿硬币
  • Effective Python 条款5 用辅助函数取代复杂的表达式
  • 数据结构:位图
  • 【保姆级目标检测教程】Ubuntu 20.04 部署 YOLOv13 全流程(附训练/推理代码)
  • Rust DevOps框架管理实例
  • 基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
  • 实时音视频通过UDP打洞实现P2P优先通信
  • C++--AVL树
  • 第一章、RNN(循环神经网络)
  • 怪物机制分析(有限状态机、编辑器可视化、巡逻机制)
  • Android UI 组件系列(四):EditText 使用详解与输入限制
  • 后台设计指南:系统架构、交互规范与工具实战全流程解析
  • 布隆过滤器+缓存穿透
  • 智能推荐社交分享小程序(websocket即时通讯、协同过滤算法、时间衰减因子模型、热度得分算法)
  • 【论文阅读】Improving the Diffusability of Autoencoders
  • Word2Vec模型详解:CBOW与Skip-gram
  • 结构化数据格式解析:JSON 与 XML 的技术应用与实践
  • Serverless 数据库来了?无服务器数据库 vs 传统数据库有何不同?
  • MySQL索引面试问题梳理
  • 华为eNSP防火墙实验(包含详细步骤)
  • Spring AI:检索增强生成(RAG)
  • SystemVerilog 断言重复操作符和序列操作符