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


前言

在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 网关超时

示例

javascript 复制代码
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自定义

javascript 复制代码
import { HttpException, HttpStatus } from '@nestjs/common';

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

封装成一个类

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

自定义响应模块

敬请期待...

相关推荐
zhensherlock13 小时前
Protocol Launcher 系列:Trello 看板管理的协议自动化
前端·javascript·typescript·node.js·自动化·github·js
iNgs IMAC18 小时前
如何在Windows系统上安装和配置Node.js及Node版本管理器(nvm)
windows·node.js
ZJY13220 小时前
3-12:路由和重构
后端·node.js
亿牛云爬虫专家1 天前
告别空壳HTML!Node.js + Playwright + 代理IP 优雅抓取动态网页实战
node.js·html·爬虫代理·动态网页·数据抓取·代理ip·playwright
Z_Wonderful1 天前
微前端:Webpack 配置 vs Vite 配置 超清晰对比
前端·webpack·node.js
不会敲代码11 天前
MCP 进阶实战:用 LangChain 将 MCP 工具集成到你的 AI Agent 程序
langchain·node.js·mcp
2601_949816681 天前
Node.js v16 版本安装
node.js
.ZGR.1 天前
【全栈实战】搭建属于你的AI图像生成平台:从Java Swing 到 Web 应用
java·人工智能·node.js
invicinble1 天前
前端技术栈--webpack
前端·webpack·node.js
yuanlaile1 天前
NestJS实战商城与云原生落地指南
云原生·nestjs·nestjs学习指南