如何在 NestJS 中处理异常?

NestJS 提供了强大的异常处理机制。可以通过 @Catch() 装饰器创建自定义异常过滤器来捕获和处理异常。例如:

typescript复制代码

typescript 复制代码
import { ExceptionFilter, Catch, ArgumentsHost, HttpException, HttpStatus } 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();

    response.status(status).json({
      statusCode: status,
      timestamp: new Date().toISOString(),
      path: request.url,
      message: exception.message,
    });
  }
}

在模块中全局注册异常过滤器:

typescript复制代码

python 复制代码
import { Module, APP_FILTER } from '@nestjs/common';
import { APP_INTERCEPTOR } from '@nestjs/core';
import { HttpExceptionFilter } from './http-exception.filter';

@Module({
  providers: [
    {
      provide: APP_FILTER,
      useClass: HttpExceptionFilter,
    },
  ],
})
export class AppModule {}

这样,所有未捕获的 HttpException 都会被 HttpExceptionFilter 处理,返回统一的错误响应格式。

相关推荐
Data_Adventure3 分钟前
Vue 3 手机外观组件库
前端·github copilot
泯泷8 分钟前
Tiptap 深度教程(二):构建你的第一个编辑器
前端·架构·typescript
屁__啦15 分钟前
前端错误-null结构
前端
lichenyang45315 分钟前
从0开始的中后台管理系统-5(userList动态展示以及上传图片和弹出创建用户表单)
前端
未来之窗软件服务19 分钟前
解析 div 禁止换行与滚动条组合-CSS运用
前端·css
不远处的小阿秋40 分钟前
2025年,前端还需要虚拟DOM吗
前端
DcTbnk1 小时前
tailwindcss、postcss、autoprefixer,这三个分别是干嘛的
前端
zReadonly1 小时前
antdv@4.x在360极速浏览器兼容解决办法
前端
yede1 小时前
页面中模块通讯简单实现
前端·javascript·html
前端Hardy1 小时前
HTML&CSS&JS:超级惊艳的全屏图片轮播效果
前端·javascript·css