如何在 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 处理,返回统一的错误响应格式。

相关推荐
SoaringHeart3 分钟前
Flutter组件封装:页面点击事件拦截
前端·flutter
杨天天.5 分钟前
小程序原生实现音频播放器,下一首上一首切换,拖动进度条等功能
前端·javascript·小程序·音视频
Dragon Wu15 分钟前
React state在setInterval里未获取最新值的问题
前端·javascript·react.js·前端框架
Jinuss16 分钟前
Vue3源码reactivity响应式篇之watch实现
前端·vue3
YU大宗师19 分钟前
React面试题
前端·javascript·react.js
木兮xg19 分钟前
react基础篇
前端·react.js·前端框架
ssshooter43 分钟前
你知道怎么用 pnpm 临时给某个库打补丁吗?
前端·面试·npm
IT利刃出鞘1 小时前
HTML--最简的二级菜单页面
前端·html
yume_sibai2 小时前
HTML HTML基础(4)
前端·html
给月亮点灯|2 小时前
Vue基础知识-Vue集成 Element UI全量引入与按需引入
前端·javascript·vue.js