nest自定义验证类及自定义验证装饰器

简介: nest自定义验证类及自定义验证装饰器

书接上回,我们在class-validator发现了许多优秀的验证规则,但是在我们实际开发需求中,有很多地方需要验证,但是包缺少了,这个时候只能我们自己去写了,我们也是根据这个包的文档去实现自定义验证。


image.png


自定义验证类

这次我们以常见的注册模块中的两次密码验证为例带领大家来实现一下。


首先创建一个post请求用于表单提交的验证,并使用管道,管道在上一篇有提到过,相信看到这里的小伙伴都了解管道了,不多说,管道代码给大家贴出

import { ArgumentMetadata, BadRequestException, HttpException, HttpStatus, Injectable, PipeTransform } from '@nestjs/common';
import { plainToInstance } from 'class-transformer'
import { validate } from 'class-validator';
@Injectable()
export class MengPipe implements PipeTransform {
  async transform(value: any, metadata: ArgumentMetadata) {
    const object = plainToInstance(metadata.metatype, value)
    const errors = await validate(object)
    if (errors.length) {
      const messages = errors.map(error => ({
        name: error.property,
        message: Object.values(error.constraints).map(v => v)
      }))
      throw new HttpException(messages, HttpStatus.BAD_REQUEST)
    }
    return value
  }
}

接着在dto文件夹下面创建一个验证密码的文件,这两个都是class-validator给我们提供的可以直接用,上篇文章都有讲

image.png

接着在github找到这个地方


image.png    

image.png


将代码复制下来后,接着创建一个rules文件夹存放自定义验证规则


image.png


我们在使用的时候其实就是向外暴露了validate这个函数,下面的defaultMessage是返回我们的报错信息的,所以结构还是比较简单的,具体可以看官方文档,很清晰。


我们对代码来简单调整一下


装饰器里面的用不到,先给他拿走, 来看看text以及args里面是啥东西

image.png

先把这个服务类在dto里面注册一下,让它明确我们要验证的是密码

image.png

image.png

image.png


image.png


这里返回的是错误不用管,因为我们validate返回的是fasle


text就是我们要验证的字段的数值


args可以拿到很多属性,这样我们就可以做验证了

image.png


image.png

image.png


 当我们输入正确时可以成功返回,不正确时也能够捕捉错误


但是我们的写法有点low,来优化一下


image.png


这样,如果有很多需要验证的我们都可以用这一个验证类,达到复用的效果。


自定义验证装饰器

我们来用唯一字段验证这个例子带领大家掌握这个的用法


image.png


我们在rules下创建一个is_not_exist.ts文件


image.png


这个类型报错可以这样解决

image.png

把这个装饰器给引入一下


image.png


我们发现需要传入1~2个参数 property validationOptions ,也就是下面这里要传的参数


image.png


我们先在mysql中创建一条表数据


image.png


我们这里就以的添加表字段为例,实现一下验证装饰器的用法


我们以prisma实例来写一个查表的方法 这里要注意异步处理。


image.png


我们用的是是user这张表,所以传的property是'user'


当我们发起一个携带同样的username的post请求时 发现已经成功实现  ,正常请求也是没有问题


image.png


image.png


写在最后    

nest有很多值得我们去探索的东西,我总结的都是在开发中大概率会用到的,希望能帮助到大家!

相关文章
|
5天前
|
JavaScript 前端开发 算法
< 封装公共导出模块:配合element实现提示 >
在 Vue + elementUi 开发中,我们偶尔会遇到需要导出的列表,或者指定位置的导出内容。在一个项目里面是十分常见的,但是由于导出代码有稍微有点长,不方便维护!基于项目开发需求,封装了一个公用的导出模块,模块入口提供了 四个参数,分别是:导出接口地址导出参数对象导出文件名称导出时选择的服务地址(需要配合config文件实现选择功能)。且基于信息安全问题,实现信息提示,当提示点击遵守规则才允许下载文件!
< 封装公共导出模块:配合element实现提示 >
|
7月前
|
数据安全/隐私保护
fastadmin中写接口是时Validate规则验证自定义如何用
fastadmin中写接口是时Validate规则验证自定义如何用
|
5天前
|
存储 API
功能定义
功能定义.
61 1
功能定义
|
5月前
|
前端开发 小程序 PHP
laravel5.8(四)引入自定义常量文件及公共函数文件
开发过程中,我们一般会用到一些不会改变,或者改变不是很频繁的值,这样的值我们一般将他们定义成常量。 比如网站根目录,或者分页数,或者域名等等。 那我们如何在laravel5.8中引入自定义的常量文件及公共的函数文件呢。 大概有两种方式: 1:框架目录下引入(不推荐) 在框架目录vendor下新建常量文件const.php,以及公共函数文件function.php 在autoload.php文件中引入。 这种方法是可以的,但是不推荐,框架目录下最好都是框架自己的那些文件,正常来说,框架的文件我们在开发过程中,git是不会进行托管的。 2:在app目录下引入 在bootstrap目录下新建常量文件
30 0
|
11月前
index.js:39 错误:修饰类属性失败。请确保提案类属性已启用并设置为使用松散模式。要在规范模式下将提案类属性与修饰器一起使用,请在阶段 2 中等待下一个主要版本的装饰器。 #79
index.js:39 错误:修饰类属性失败。请确保提案类属性已启用并设置为使用松散模式。要在规范模式下将提案类属性与修饰器一起使用,请在阶段 2 中等待下一个主要版本的装饰器。 #79
54 0
接口参数注解验证案例
写作缘由 写接口的时候经常会有请求体里某字段不为null的需求;也有使用一个dto对象,但是插入和修改都想使用这个dto,那这样的话判断条件就不一样,因为修改操作必须有ID,所以参数验证还是挺麻烦的。所以写个demo记录一下,亲测可用。
117 0
【Nest教程】为项目增加个自定义过滤器
【Nest教程】为项目增加个自定义过滤器
181 0
【Nest教程】为项目增加个自定义过滤器
【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 @Mixin 注解进行方法注入 | Mixin 混合多个类优先级分析 )
【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 @Mixin 注解进行方法注入 | Mixin 混合多个类优先级分析 )
121 0
【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 分析使用 MetaClass 进行方法注入前后 mateClass 类型变化 )
【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 分析使用 MetaClass 进行方法注入前后 mateClass 类型变化 )
120 0
【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 Mixin 混合进行方法注入 )
【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 Mixin 混合进行方法注入 )
113 0
【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 Mixin 混合进行方法注入 )