服务端之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);
  }
}

自定义响应模块

敬请期待...

相关推荐
郭庆汝2 小时前
Ubuntu安装Node.js
linux·ubuntu·node.js
wellc2 小时前
如何在Windows系统上安装和配置Node.js及Node版本管理器(nvm)
windows·node.js
不会写DN3 小时前
从依赖到自主:手写一个 ICO 文件转换器
前端·javascript·typescript·node.js
zybsjn4 小时前
一天快速实现markdown 编辑器和排版工具:基于Node.js + Express + 原生JS的开发实践
node.js·express·ai编程
书中枫叶4 小时前
个人主页网站SEO | 个人博客基于Nuxt
typescript·node.js·nuxt.js
木易 士心4 小时前
Node.js 后端开发全解析:从核心原理架构到实战应用
后端·架构·node.js
H5css�海秀12 小时前
今天是自学大模型的第一天(sanjose)
后端·python·node.js·php
求知若饥20 小时前
webpage-channel 让不同页面通信像组件通信一样简便
前端·typescript·node.js
小霍同学21 小时前
NVM —— Node.js 版本管理工具
node.js
嵌入式-老费21 小时前
vivado hls的应用(axis接口)
前端·webpack·node.js