服务端之nestJS常用异常类及封装自定义响应模块

发布于:2025-08-06 ⋅ 阅读:(16) ⋅ 点赞:(0)


前言

在NestJS中,@nestjs/common提供了大量的内置异常类,主要用于在控制器、服务等层抛出特定的HTTP错误响应。


常用异常类(由@nestjs/common提供)

序号 异常类 状态码 说明
01 BadRequestException 400 客户端请求参数错误、验证失败
02 UnauthorizedException 401 未授权,常用于认证失败(账号/密码错误、token无效等)
03 ForbiddenException 403 无权限访问(即使已认证)
04 NotFoundException 404 找不到资源(如用户不存在)
05 MethodNotAllowedException 405 不允许的请求方法
06 NotAcceptableException 406 请求格式不可接受(比如响应类型不被支持)
07 RequestTimeoutException 408 请求超时
08 ConflictException 409 资源冲突(如重复注册、唯一索引冲突)
09 GoneException 410 资源已被永久删除
10 PayloadTooLargeException 413 请求体过大(文件上传)
11 UnsupportedMediaTypeException 415 不支持的媒体类型(如上传类型错误)
12 UnprocessableEntityException 422 语义错误、验证失败(用于复杂验证)
13 InternalServerErrorException 500 服务端错误
14 NotImplementedException 501 接口未实现
15 BadGatewayException 502 网关错误
16 ServiceUnavailableException 503 服务不可用(服务器维护、宕机等)
17 GatewayTimeoutException 504 网关超时

示例

import {
  BadRequestException,
  UnauthorizedException,
  NotFoundException,
  ConflictException,
} from '@nestjs/common';

if (!user) throw new NotFoundException('用户不存在');
if (!isPasswordValid) throw new UnauthorizedException('账号或密码错误');
if (emailAlreadyUsed) throw new ConflictException('该邮箱已被注册');
if (!dto.name) throw new BadRequestException('用户名不能为空');

自定义异常(可选)

可以继承HttpException自定义

import { HttpException, HttpStatus } from '@nestjs/common';

throw new HttpException('自定义错误信息', HttpStatus.BAD_REQUEST);

封装成一个类

export class CustomException extends HttpException {
  constructor() {
    super('这是一个自定义异常', HttpStatus.I_AM_A_TEAPOT);
  }
}

自定义响应模块

敬请期待…


网站公告

今日签到

点亮在社区的每一天
去签到