NestJS入门及实战(三)接口数据校验

管道Pipe是什么

中文文档

https://docs.nestjs.cn/9/pipes

在这里插入图片描述
在这里插入图片描述

一个可注入类(@Injectable()可以使用Pipe完成输入输出参数的事前和事后处理。

主要应用场景

  • 验证: 对输入数据进行验证,验证通过继续传递,否则抛出异常。
  • 转化: 将输入数据转化后输出。

这里我们主要说的就是验证

数据校验实战

安装依赖

pnpm i class-validator class-transformer

在这里插入图片描述

全局使用

src/main.ts

async function bootstrap() {
  const app = await NestFactory.create(AppModule);
  
  // 添加全局管道
  app.useGlobalPipes(new ValidationPipe())

  await app.listen(3000);
}
bootstrap();

create-user.dto.ts

import { ApiProperty } from "@nestjs/swagger"
import { IsNotEmpty, Matches } from 'class-validator'

export class CreateUserDto {
    @ApiProperty({ example: "shaka" })
    @IsNotEmpty()
    name: string

    @ApiProperty({ example: "male" })
    @IsNotEmpty()
    sex: string

    @ApiProperty({ example: "123" })
    @Matches(/^1\d{10}$/g, { message: '请输入手机号' })
    phone: string
}

在这里插入图片描述
在这里插入图片描述
我们测试一下,讲名字设置为空
在这里插入图片描述
可以看到返回了对应的结果
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
NestJS ,可以使用 class-validator 库进行请求参数校验。下面是一个简单的示例代码: 1. 首先,您需要安装 class-validator 和 class-transformer 库: ``` npm install class-validator class-transformer ``` 2. 在您的 DTO(Data Transfer Object)类定义请求参数的验证规则。例如,假设您有一个 UserDto 类来处理用户注册请求: ```typescript import { IsNotEmpty, IsEmail } from 'class-validator'; export class UserDto { @IsNotEmpty() username: string; @IsNotEmpty() @IsEmail() email: string; @IsNotEmpty() password: string; } ``` 3. 在您的控制器使用这个 DTO 类,并使用 @Body() 装饰器将请求体绑定到 DTO 对象: ```typescript import { Controller, Post, Body } from '@nestjs/common'; import { UserDto } from './user.dto'; @Controller('users') export class UserController { @Post() createUser(@Body() userDto: UserDto) { // 这里的 userDto 将自动根据定义的验证规则进行校验 // 如果校验失败,NestJS 会抛出 BadRequestException 异常 // 您可以在这里处理校验失败的逻辑 // 如果校验通过,可以继续处理用户注册逻辑 // ... } } ``` 在上述示例,我们使用了 IsNotEmpty 和 IsEmail 等验证装饰器来定义验证规则。您可以根据需要使用其他 class-validator 提供的装饰器来定义更复杂的验证规则。 请注意,NestJS 默认情况下会使用 class-transformer 库对请求体进行转换。这意味着,如果您在请求体接收的是 JSON 字符串,NestJS 会自动将其转换为 DTO 对象。如果您不想使用这种转换,请在 main.ts 文件禁用它: ```typescript import { NestFactory } from '@nestjs/core'; import { AppModule } from './app.module'; async function bootstrap() { const app = await NestFactory.create(AppModule, { bodyParser: false }); await app.listen(3000); } bootstrap(); ``` 以上就是在 NestJS 进行请求参数校验的基本方法。您可以根据具体的需求进一步扩展和定制验证规则。希望能对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

林多多@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值