当前位置: 首页 > news >正文

【Express.js】express-validator

express-validator

express.js 集成 express-validator进行数据校验

在最初的时候,对于请求的数据校验,我们是自定义一个中间件,然后在里面通过最原生的方式检验。在本节,我们将尝试用一种更优雅的方式进行数据校验。

准备工作

创建一个基础的 express 项目(本文基于evp-express-cli),并支持全局同步和异步错误错误处理。

安装express-validator,并引入:

npm i express-validator
const validator = require('express-validator');

验证链

validator:

  • body()
  • cookie()
  • header()
  • param()
  • query()

validator.query为例,我们可以检查query参数中的某一项

router.get('/greet', validator.query('person').trim().notEmpty().escape().withMessage("person不能为空"),
(req, res, next) => {const valires = validator.validationResult(req);if (!valires.isEmpty()) {const err = new Error(valires.array()[0].msg);throw err;}logger.info(`Hello ${req.query.person}!`);res.send(`Hello ${req.query.person}!`);
});

validationResult()用法获取校验结果,valires是校验结果,主要结构如下:

{//...errors: []
}

errors需要通过valires.array()来得到,当然序列反序列化也行
每一项error结构如下:

{"type": string,"msg": string,"path": string, //如上面检查的person"location": string //如query,body..
}

如果需要检验多个参数,就放进数组即可:

[validator.query('person').trim().notEmpty().escape().withMessage("person不能为空"),validator.query('address').trim().notEmpty().escape().withMessage("address不能为空")
]

封装剥离

之前的写法,是把错误处理和定义都直接写在路由上,臃肿且代码侵入性较强,我们可以进一步封装:

Checker:
这个示例采取了检验并发竞赛的机制,你也可以使用其它的并发或者同步机制:

/*** Validator Race checker* @param {validator.ValidationChain[]} validChain * @returns */
const ValidRace = (validChain)=>{return async (req, res, next) => {await Promise.race(validChain.map(validate => validate.run(req)))const valires = validator.validationResult(req);if (!valires.isEmpty()) {console.log(valires.array());const err = new Error(valires.array()[0].msg);throw err;}next();}
}

然后在路由上使用即可:

router.get('/greet2',ValidRace([validator.query('age').trim().notEmpty().withMessage("age不能为空").bail().isInt().withMessage("age必须是正整数").bail().toInt()]),
(req, res, next) => {logger.info(`Hello ${req.query.person}!`);res.send(`Hello ${req.query.person}!`);
});

bail()的用处是,如果前面出错就终止检验链,不加的话,age空了还会往后面检验是不是整数。

当然你也可以赋给一个变量,然后再引进来:

const CheckGreet2 = ValidRace([validator.query('age').trim().notEmpty().withMessage("age不能为空").bail().isInt().withMessage("age必须是正整数").bail().toInt()
]);
router.get('/greet2', CheckGreet2, (req, res, next) => {logger.info(`Hello ${req.query.person}!`);res.send(`Hello ${req.query.person}!`);
});

express-validator的用法远远不止于此,详见官方文档https://express-validator.github.io/docs


下一节-使用zod检验

相关文章:

【Express.js】express-validator

express-validator express.js 集成 express-validator进行数据校验 在最初的时候,对于请求的数据校验,我们是自定义一个中间件,然后在里面通过最原生的方式检验。在本节,我们将尝试用一种更优雅的方式进行数据校验。 准备工作…...

沁恒ch32V208处理器开发(三)GPIO控制

目录 GPIO功能概述 CH32V2x 微控制器的GPIO 口可以配置成多种输入或输出模式,内置可关闭的上拉或下拉电阻,可以配置成推挽或开漏功能。GPIO 口还可以复用成其他功能。端口的每个引脚都可以配置成以下的多种模式之一: 1 浮空输入 2 上拉输入…...

Jenkins 中 shell 脚本执行失败却不自行退出

Jenkins 中 执行 shell 脚本时,有时候 shell 执行失败了,或者判断结果是错误的,但是 Jenkins 执行完成后确提示成功 success 。 此时,可以通过条件判断来解决这个问题,让 Jenkins 强制退出并提示执行失败 failed 。 …...

2021年12月 C/C++(一级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题:输出整数部分 输入一个双精度浮点数f, 输出其整数部分。 时间限制:1000 内存限制:65536 输入 一个双精度浮点数f(0 < f < 100000000)。 输出 一个整数,表示浮点数的整数部分。 样例输入 3.8889 样例输出 3 下面是一个使用C语言编写的输出双精度浮点数整数部分…...

计算机网络 网络层 IPv4数据报

...

有哪些可以用于性能测试方法?【举例说明】

1.负载测试 在这里&#xff0c;负载测试指的是最常见的验证一般性能需求而进行的性能测试&#xff0c;在上面我们提到了用户最常见的性能需求就是“既要马儿跑&#xff0c;又要马儿少吃草”。因此负载测试主要是考察软件系统在既定负载下的性能表 现。我们对负载测试可以有如下…...

Linux进程管理命令

一、进程 程序由一条条指令构成&#xff0c;在运行一个程序的时候就是把这些指令从第一条执行到最后一条&#xff0c;而进程是一个正在运行的程序。 比如说&#xff0c;一个main.c文件是不可以直接运行的&#xff0c;对main.c进行编译链接之后生成一个main.exe&#xff08;在W…...

pytest 常用命令参数

-x 用例一旦失败或错误时就立即停止执行 共两条用例&#xff0c;运行第一条报错失败或报错&#xff0c;第二条就不会执行 pytest -vs -x test_pytest_study.py::TestCommon1 共2条用例&#xff0c;当执行到第一条失败时候&#xff0c;第二条不执行 --maxfailnum …...

从安装 Seata 开始的分布式事务之旅 springboot集成seata

从安装 Seata 开始的分布式事务之旅 介绍什么是 Seata&#xff1f; 安装 Seata Server下载 Seata Server 发行版配置Seata解压文件配置Seata的yml文件把配置文件config.txt加载到nacos上修改config.txt文件加载到nacos上 启动Seata服务正常启动查看启动日志打开控制台页面 启动…...

Laravel 使用mix引入本地样式文件 报错 Unable to locate Mix处理

刚下了一个bootstrap样式文件&#xff0c;mix引入了一下&#xff0c;直接报错&#xff1a; Unable to locate Mix file: /css/bootstrap.min.css. (View: D:\phpEnv\www\abc\resources\views\admin\noteAdd.blade.php)原来是需要 npm run dev 启动一下 ✔ Compiled Successfu…...

QT学习笔记-QT安装oracle oci驱动

QT学习笔记-QT安装oracle oci驱动 0、背景1、环境以及条件说明2、编译驱动2.1 下载oracle instant client2.2 编译qt oci驱动2.2.1 修改oci.pro2.2.2 MinGW64构建套件编译2.2.3 MSVC2019_64构建套件编译 3、访问数据库运行成功 0、背景 在使用QT开发应用的过程中&#xff0c;往…...

【React学习】—类的基本知识(五)

【React学习】—类的基本知识&#xff08;五&#xff09; <script>// 创建一个Person类class Person{//构造器方法constructor(name,age){this.namename;this.ageage;}//一般方法speak(){//speak方法一般放在哪里&#xff1f;类的原型上&#xff0c;供实例使用//通过Pers…...

【AI】《动手学-深度学习-PyTorch版》笔记(十六):自定义网络层、保存/加载参数、使用GPU

AI学习目录汇总 1、自定义网络层 自定义网络层很简单,三步即可完成 继承类:nn.Module定义初始化函数:__init__中定义需要初始化的代码定义向前传播函数:forward1.1 不带参数的网络层 1)定义网络层 import torch import torch.nn.functional as F from torch import nn…...

微软杀入Web3:打造基于区块链的AI产品

作者&#xff1a;秦晋 2023年1月&#xff0c;微软向 ChatGPT 创建者 OpenAI 投资 100 亿美元&#xff0c;在AI业界引发格外关注。此举也让微软在AI的战略探索上提前取得有利位置。 2023年3月&#xff0c;微软软件工程师 Albacore 披露微软正在为Edge 浏览器测试内置的非托管加密…...

聊聊51单片机

目录 1.介绍 2.发展 3.应用领域 4.发展前景 1.介绍 51单片机&#xff08;AT89C51&#xff09;是一种常见的8位微控制器&#xff0c;属于Intel MCS-51系列。它是一种低功耗、高性能的单片机&#xff0c;广泛应用于嵌入式系统中。 51单片机具有很多特点和功能&#xff0c;例如…...

Linux yum 命令,Linux apt 命令

目录 Linux yum 命令 yum 语法 yum常用命令 实例 1 实例 2 实例 3 国内 yum 源...

Vue+SpringBoot项目开发:登录页面美化,登录功能实现(三)

写在开始:一个搬砖程序员的随缘记录上一章写了从零开始VueSpringBoot后台管理系统&#xff1a;Vue3TypeScript项目搭建 VueTypeScript的前端项目已经搭建完成了 这一章的内容是引入element-plus和axios实现页面的布局和前后端数据的串联&#xff0c;实现一个登陆的功能&#x…...

2.若依前后端分离版第一个增删查改

1.介绍 若依提供了代码生成功能&#xff0c;单表的CRUD可以直接用若依框架提供的代码生成进行创建。 2.实现 2.1 在数据库创建业务表test_teacher 2.2 生成代码 运行系统&#xff0c;进入菜单[系统工具]-》[代码生成],点击导入按钮&#xff0c;选择需要生成代码的表进行导…...

javaSE_2.2——【方法的介绍】

1.方法的定义 &#xff08;1&#xff09;方法声明的语法规则如下所示&#xff1a; [修饰符] 返回值类型 方法名称([参数列表]){// 方法体 } 方法修饰符&#xff1a;是一种关键字&#xff0c;用来描述方法、类、变量等各种元素的声明&#xff0c;一个程序可以同时拥有多个修饰…...

【02】基础知识:typescript数据类型

1、布尔类型 boolean let flag: boolean false2、数字类型 number let num: number 6 //十进制 let num2: number 0xf00d //十六进制 let num3: number 0b1010 //二进制 let num4: number 0o744 //八进制3、字符串类型 string 用双引号&#xff08;“&#xff09;或单引…...

如何用LunaTranslator打破游戏语言壁垒:3种实时翻译方法全解析

如何用LunaTranslator打破游戏语言壁垒&#xff1a;3种实时翻译方法全解析 【免费下载链接】LunaTranslator 视觉小说翻译器 / Visual Novel Translator 项目地址: https://gitcode.com/GitHub_Trending/lu/LunaTranslator 还在为看不懂日文游戏剧情而烦恼吗&#xff1f…...

从单表到多模块:MyBatis-Plus-Generator 3.5.2 在微服务项目中的高级玩法与避坑指南

从单表到多模块&#xff1a;MyBatis-Plus-Generator 3.5.2 在微服务项目中的高级玩法与避坑指南 当你的项目从单体架构演进为微服务体系时&#xff0c;那些曾经得心应手的工具链往往会暴露出新的挑战。MyBatis-Plus-Generator作为持久层开发的利器&#xff0c;在单体项目中可能…...

基于LangChain.js与MCP协议构建AI智能体:从本地开发到Azure部署实战

1. 项目概述&#xff1a;一个基于LangChain.js与MCP的汉堡店AI点餐代理 如果你正在寻找一个能完整展示如何将大型语言模型&#xff08;LLM&#xff09;与真实世界API连接起来的实战项目&#xff0c;那么这个由Azure-Samples开源的“mcp-agent-langchainjs”仓库绝对值得你花时间…...

嵌入式系统-73:RT-Thread-组件:utest框架在持续集成中的实战应用

1. 为什么嵌入式开发需要持续集成测试 第一次接触嵌入式系统的持续集成时&#xff0c;我完全不明白为什么要在资源受限的设备上搞这些"花里胡哨"的东西。直到某次项目交付前夜&#xff0c;一个基础驱动模块的改动导致整个系统崩溃&#xff0c;团队通宵排查问题的惨痛…...

如何快速部署EspoCRM:5个步骤掌握开源客户关系管理系统的完整安装指南

如何快速部署EspoCRM&#xff1a;5个步骤掌握开源客户关系管理系统的完整安装指南 【免费下载链接】espocrm EspoCRM – Open Source CRM Application 项目地址: https://gitcode.com/GitHub_Trending/es/espocrm 想要提升企业客户关系管理效率却担心高昂的软件成本&…...

别再死记硬背了!用‘生命体’比喻彻底搞懂UVM的component与object

别再死记硬背了&#xff01;用‘生命体’比喻彻底搞懂UVM的component与object 在芯片验证领域&#xff0c;UVM&#xff08;Universal Verification Methodology&#xff09;作为行业标准方法论&#xff0c;其核心架构设计常常让初学者感到困惑。特别是uvm_component与uvm_obje…...

一场互联网大厂的面试故事:Java求职者谢飞机的精彩(或滑稽)回答

一场互联网大厂的面试故事&#xff1a;Java求职者谢飞机的精彩&#xff08;或滑稽&#xff09;回答 面试场景设定 谢飞机&#xff0c;一位自认为熟悉Java及周边技术的程序员&#xff0c;来到了某互联网大厂的总部进行面试。面试官是一位技术沉稳、逻辑清晰的大拿&#xff0c;带…...

FPGA实战:用AXI Quad SPI IP核驱动Winbond W25Q128 Flash(附完整Tcl脚本)

FPGA实战&#xff1a;AXI Quad SPI IP核驱动Winbond W25Q128 Flash全流程解析 在嵌入式存储解决方案中&#xff0c;SPI Flash因其高性价比和小型封装成为FPGA外设配置、数据存储的热门选择。Winbond W25Q128作为128Mbit容量的工业级NOR Flash&#xff0c;支持标准SPI、Dual SPI…...

Keras实现一维生成对抗网络(1D GAN)实战指南

1. 从零构建一维生成对抗网络的核心价值第一次接触GAN时&#xff0c;我被它生成逼真图像的能力震撼。但当我真正尝试用GAN处理一维时序数据时&#xff0c;才发现这个领域存在明显的资源断层——大多数教程都集中在二维图像生成&#xff0c;而实际业务中传感器数据、音频波形、金…...

探索未来云计算的航标:Crane如何简化容器编排管理

探索未来云计算的航标&#xff1a;Crane如何简化容器编排管理 【免费下载链接】crane Yet another control plane based on docker built-in swarmkit 项目地址: https://gitcode.com/gh_mirrors/crane/crane 在当今快速发展的云计算领域&#xff0c;容器编排已成为构建…...