【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语言编写的输出双精度浮点数整数部分…...
有哪些可以用于性能测试方法?【举例说明】
1.负载测试 在这里,负载测试指的是最常见的验证一般性能需求而进行的性能测试,在上面我们提到了用户最常见的性能需求就是“既要马儿跑,又要马儿少吃草”。因此负载测试主要是考察软件系统在既定负载下的性能表 现。我们对负载测试可以有如下…...
Linux进程管理命令
一、进程 程序由一条条指令构成,在运行一个程序的时候就是把这些指令从第一条执行到最后一条,而进程是一个正在运行的程序。 比如说,一个main.c文件是不可以直接运行的,对main.c进行编译链接之后生成一个main.exe(在W…...
pytest 常用命令参数
-x 用例一旦失败或错误时就立即停止执行 共两条用例,运行第一条报错失败或报错,第二条就不会执行 pytest -vs -x test_pytest_study.py::TestCommon1 共2条用例,当执行到第一条失败时候,第二条不执行 --maxfailnum …...
从安装 Seata 开始的分布式事务之旅 springboot集成seata
从安装 Seata 开始的分布式事务之旅 介绍什么是 Seata? 安装 Seata Server下载 Seata Server 发行版配置Seata解压文件配置Seata的yml文件把配置文件config.txt加载到nacos上修改config.txt文件加载到nacos上 启动Seata服务正常启动查看启动日志打开控制台页面 启动…...
Laravel 使用mix引入本地样式文件 报错 Unable to locate Mix处理
刚下了一个bootstrap样式文件,mix引入了一下,直接报错: 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开发应用的过程中,往…...
【React学习】—类的基本知识(五)
【React学习】—类的基本知识(五) <script>// 创建一个Person类class Person{//构造器方法constructor(name,age){this.namename;this.ageage;}//一般方法speak(){//speak方法一般放在哪里?类的原型上,供实例使用//通过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产品
作者:秦晋 2023年1月,微软向 ChatGPT 创建者 OpenAI 投资 100 亿美元,在AI业界引发格外关注。此举也让微软在AI的战略探索上提前取得有利位置。 2023年3月,微软软件工程师 Albacore 披露微软正在为Edge 浏览器测试内置的非托管加密…...
聊聊51单片机
目录 1.介绍 2.发展 3.应用领域 4.发展前景 1.介绍 51单片机(AT89C51)是一种常见的8位微控制器,属于Intel MCS-51系列。它是一种低功耗、高性能的单片机,广泛应用于嵌入式系统中。 51单片机具有很多特点和功能,例如…...
Linux yum 命令,Linux apt 命令
目录 Linux yum 命令 yum 语法 yum常用命令 实例 1 实例 2 实例 3 国内 yum 源...
Vue+SpringBoot项目开发:登录页面美化,登录功能实现(三)
写在开始:一个搬砖程序员的随缘记录上一章写了从零开始VueSpringBoot后台管理系统:Vue3TypeScript项目搭建 VueTypeScript的前端项目已经搭建完成了 这一章的内容是引入element-plus和axios实现页面的布局和前后端数据的串联,实现一个登陆的功能&#x…...
2.若依前后端分离版第一个增删查改
1.介绍 若依提供了代码生成功能,单表的CRUD可以直接用若依框架提供的代码生成进行创建。 2.实现 2.1 在数据库创建业务表test_teacher 2.2 生成代码 运行系统,进入菜单[系统工具]-》[代码生成],点击导入按钮,选择需要生成代码的表进行导…...
javaSE_2.2——【方法的介绍】
1.方法的定义 (1)方法声明的语法规则如下所示: [修饰符] 返回值类型 方法名称([参数列表]){// 方法体 } 方法修饰符:是一种关键字,用来描述方法、类、变量等各种元素的声明,一个程序可以同时拥有多个修饰…...
【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 用双引号(“)或单引…...
如何用LunaTranslator打破游戏语言壁垒:3种实时翻译方法全解析
如何用LunaTranslator打破游戏语言壁垒:3种实时翻译方法全解析 【免费下载链接】LunaTranslator 视觉小说翻译器 / Visual Novel Translator 项目地址: https://gitcode.com/GitHub_Trending/lu/LunaTranslator 还在为看不懂日文游戏剧情而烦恼吗?…...
从单表到多模块:MyBatis-Plus-Generator 3.5.2 在微服务项目中的高级玩法与避坑指南
从单表到多模块:MyBatis-Plus-Generator 3.5.2 在微服务项目中的高级玩法与避坑指南 当你的项目从单体架构演进为微服务体系时,那些曾经得心应手的工具链往往会暴露出新的挑战。MyBatis-Plus-Generator作为持久层开发的利器,在单体项目中可能…...
基于LangChain.js与MCP协议构建AI智能体:从本地开发到Azure部署实战
1. 项目概述:一个基于LangChain.js与MCP的汉堡店AI点餐代理 如果你正在寻找一个能完整展示如何将大型语言模型(LLM)与真实世界API连接起来的实战项目,那么这个由Azure-Samples开源的“mcp-agent-langchainjs”仓库绝对值得你花时间…...
嵌入式系统-73:RT-Thread-组件:utest框架在持续集成中的实战应用
1. 为什么嵌入式开发需要持续集成测试 第一次接触嵌入式系统的持续集成时,我完全不明白为什么要在资源受限的设备上搞这些"花里胡哨"的东西。直到某次项目交付前夜,一个基础驱动模块的改动导致整个系统崩溃,团队通宵排查问题的惨痛…...
如何快速部署EspoCRM:5个步骤掌握开源客户关系管理系统的完整安装指南
如何快速部署EspoCRM:5个步骤掌握开源客户关系管理系统的完整安装指南 【免费下载链接】espocrm EspoCRM – Open Source CRM Application 项目地址: https://gitcode.com/GitHub_Trending/es/espocrm 想要提升企业客户关系管理效率却担心高昂的软件成本&…...
别再死记硬背了!用‘生命体’比喻彻底搞懂UVM的component与object
别再死记硬背了!用‘生命体’比喻彻底搞懂UVM的component与object 在芯片验证领域,UVM(Universal Verification Methodology)作为行业标准方法论,其核心架构设计常常让初学者感到困惑。特别是uvm_component与uvm_obje…...
一场互联网大厂的面试故事:Java求职者谢飞机的精彩(或滑稽)回答
一场互联网大厂的面试故事:Java求职者谢飞机的精彩(或滑稽)回答 面试场景设定 谢飞机,一位自认为熟悉Java及周边技术的程序员,来到了某互联网大厂的总部进行面试。面试官是一位技术沉稳、逻辑清晰的大拿,带…...
FPGA实战:用AXI Quad SPI IP核驱动Winbond W25Q128 Flash(附完整Tcl脚本)
FPGA实战:AXI Quad SPI IP核驱动Winbond W25Q128 Flash全流程解析 在嵌入式存储解决方案中,SPI Flash因其高性价比和小型封装成为FPGA外设配置、数据存储的热门选择。Winbond W25Q128作为128Mbit容量的工业级NOR Flash,支持标准SPI、Dual SPI…...
Keras实现一维生成对抗网络(1D GAN)实战指南
1. 从零构建一维生成对抗网络的核心价值第一次接触GAN时,我被它生成逼真图像的能力震撼。但当我真正尝试用GAN处理一维时序数据时,才发现这个领域存在明显的资源断层——大多数教程都集中在二维图像生成,而实际业务中传感器数据、音频波形、金…...
探索未来云计算的航标:Crane如何简化容器编排管理
探索未来云计算的航标:Crane如何简化容器编排管理 【免费下载链接】crane Yet another control plane based on docker built-in swarmkit 项目地址: https://gitcode.com/gh_mirrors/crane/crane 在当今快速发展的云计算领域,容器编排已成为构建…...
