前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >使用joi来验证数据模型[通俗易懂]

使用joi来验证数据模型[通俗易懂]

作者头像
全栈程序员站长
发布于 2022-09-19 12:39:06
发布于 2022-09-19 12:39:06
1.2K00
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

我们用nodejs实现一些功能时,往往需要对用户输入的数据进行验证。然而,验证是一件麻烦的事情,很有可能你需要验证数据类型,长度,特定规则等等,在前端做表单验证时,我们常用的做法是使用正则,正则表达式也许可以一步到位,但是他只会给你true or false,如果想要知道数据不符合哪些条件时,那么你要进一步判断,下面和大家分享一种可读性和易用性更好的实现方法。

Joi 是 hapijs 自带的数据校验模块,他已经高度封装常用的校验功能,本文就是介绍如何优雅地使用 joi 对数据进行校验。相信你会喜欢上他。便于大家理解,以登录为例,一般分两种方式:A或B (输入密码或二维码),那么 joi 的配置如下即可实现检验:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var Joi = require('joi');
var schema = Joi.object({
    username: Joi.string().min(3).max(30).required(),
    isA: Joi.boolean(),
    AVal: Joi.number(),
    isB: Joi.boolean(),
    BVal: Joi.string()
})
.with('isA', 'AVal')
.with('isB', 'BVal')
.without('isA', 'isB')
.or('isA', 'isB');

以上scheme配置大致意思如下:

username: 字符串类型,长度在3至30之间,必填。

isA: 布尔类型,可选

AVal: 数字类型, 可选

isB: 布尔类型, 可选

BVal: 字符串类型, 可选

with(‘isA’, ‘AVal’) //意思是,isA 和 AVal 这两字段如果填写了isA,也必须要填写AVal

with(‘isB’, ‘BVal’) //道理同上

without(‘isA’, ‘isB’); //意思是 isA 和 isB 只能填写其中一个

or(‘isA’, ‘isB’) //意思是 isA 和 isB 这两字段至少填写其一

Let’s try

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var input = {
	username: 'zzbo'
}

var output = Joi.validate(input, schema);
//error: ValidationError: "value" must contain at least one of [isA, isB]

提示至少要填写 isA 或 isB 其中之一

再看:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var input = {
	username: 'zzbo',
    isA: true
}

var output = Joi.validate(input, schema);
//error: ValidationError: "isA" missing required peer "AVal"

提示 AVal 必填

再来:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var input = {
	username: 'zzbo',
    isA: true,
    AVal: 666666
}

var output = Joi.validate(input, schema);
//error: null

成功通过校验

这种极简易读的表达方式让你轻松快速实现校验功能,不需要 if else。这就是配置大于编码的魅力。

不仅于scheme对象

joi 不仅仅作用于scheme对象,而且还可以单独使用,比如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Joi.string().validate(666666);  //error: ValidationError: "value" must be a string
Joi.string().validate('hehe'); // pass

有时一些意外的字段被传进来,会导致校验不通过,但你又不在乎这些多余的字段,可以这样配置:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Joi.validate({y: 3}, {x: Joi.string()}); // [ValidationError: "y" is not allowed]
Joi.validate({y: 3}, {x: Joi.string()}, {allowUnknown: true}); // pass, 配置 {allowUnknown: true}

除了表单常用的数值,布尔类型等,也可以校验函数类型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var myObject = {
    a: 123,
    b: function () { }
}

var schema = {
  a: Joi.number().integer(),
  b: Joi.func()
}

Joi.validate(myObject, schema);
//pass

除此之外,还有更多类型Joi.any(), Joi.array(), Joi.boolean(), Joi.date(), Joi.func(), Joi.number(), Joi.object(), Joi.string()

更多玩法

数字 + 特定的字符串:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Joi.number().allow('a').validate('a');  // pass
Joi.number().valid('a').validate('a');   // pass  
Joi.number().valid(['a', 'b']).validate('b');   // pass  
Joi.number().allow('a').validate(3);   // pass

不能是数字5:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Joi.number().invalid(5).validate(5);  // error

允许是任何类型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Joi.any().validate() // pass

如果需要校验对象的子对象,那么Joi的描述也可以作为了一个子对象:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var Joi = require('joi');

var schemeAB = Joi.object({
  A: Joi.string().required(),
  B: Joi.string().required()
});

var schemeCD = Joi.object({
  C: Joi.string().required(),
  D: schemeAB  //可以作为子对象
});

var output = Joi.validate({
  C: 'hehe',
  D: {
    A: 'haha',
    B: 'hoho'
  }
}, schemeCD);

console.log(output);
//pass

Joi提供的校验条件不够用?也可以使用正则:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Joi.object({
    password: Joi.string().regex(/^[a-zA-Z0-9]{3,30}$/)
});

在 hapijs 中使用Joi

hapijs 自家的Joi 当然要无缝对接起来

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var Hapi = require('hapi');
var Joi = require('Joi');

var server = new Hapi.Server();

server.connection({
    port: 8000
});

server.route({
    method: 'GET',
    path: '/',
    handler: function (request, reply) {
        if (request.query.hour && request.query.minute) {
            reply(request.query.hour + ':' + request.query.minute);
        } else {
            reply('time unknown');
        }
    },
    config: {
        validate: {
            query: {
                hour: Joi.number().min(0).max(23),
                minute: Joi.number().min(0).max(59)
            }
        }
     }
});

server.start(function(err) {
    if (err) throw err;
    console.log('Server running...');
});

就是如此简单的配置就即可完成数据验证,体配置大于 调试一下:

http://127.0.0.1:8000/?hour=2&minute=3 //pass

http://127.0.0.1:8000/?hour=2&minute=300 //error

最后

小伙伴们赶紧动手来尝试一下。

Joi 的更多用法可以参考文档:https://github.com/hapijs/joi/blob/v8.0.5/API.md

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/166635.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
校验数据结构调研
ajv和joi是两个常见的JavaScript JSON Schema 库,它们在社区生态、用法和API设计方面都有一些区别。以下是它们之间的比较:
爱吃大橘
2023/04/22
8760
前端小白玩转koa(二)
文章地址:https://cloud.tencent.com/developer/article/2471283
一起重学前端
2024/11/26
1970
JS 数据验证框架 joi
版本 joi 17.7 安装 npm i joi 使用 定义类型和约束 const schema = Joi.object({ a: Joi.string() }); 使用定义的模式校验数据 const { error, value } = schema.validate({ a: 'a string' }); 参考 官网
路过君
2022/11/21
5.9K0
Node 如何在 Controller 层进行数据校验
幽默风趣的后端程序员一般自嘲为 CURD Boy。CURD, 也就是对某一存储资源的增删改查,这完全是面向数据编程啊。
山月
2020/09/01
1.5K0
NestJS 7.x 折腾记: (2) 环境变量及配置维护
在写后端的时候,我们一般提倡配置文件分离. 所以.env就可以很方面来维护我们的环境变量, 封装对应的工厂函数也能组合更复杂的配置! 比如我们用镜像(Docker),就可以外部映射配置文件目录; 达到不同环境使用差异化配置的需求!(运行时加载是允许的!) 其他不多说,往下可以看看我的配置分离思路~~
CRPER
2022/03/08
4.3K1
NestJS 7.x 折腾记: (2) 环境变量及配置维护
2024年Node.js精选:50款工具库集锦,项目开发轻松上手(三)
大家好,今天,继续我们的Node.js探索之旅,深入了解一系列强大的工具库,它们能够帮助我们在项目开发中提升效率、加固安全、优化性能,甚至更优雅地处理数据和逻辑。
前端达人
2024/03/14
5990
2024年Node.js精选:50款工具库集锦,项目开发轻松上手(三)
NestJs 管道(Pipe)
在 Nestjs 中管道是具有 @Injectable() 装饰器且已实现 PipeTransform 接口的类。
前端小鑫同学
2023/10/16
4660
NestJs 管道(Pipe)
Express.js Tutorial: Build RESTful APIs with Node and Express | Mosh
在Youtube上看到Mosh的一篇关于使用Node和Express构建RESTful APIs的示例,对应的视频地址是:Express.js Tutorial: Build RESTful APIs with Node and Express | Mosh,作者Mosh的Youtube地址是:Programming with Mosh
ccf19881030
2020/05/18
1.7K0
利用微搭搭建答题小程序
解题的思路的话是先安装模板,然我我们在一步步的分析一下模板做了什么工作,需要做哪些改造。
低代码布道师
2021/11/07
3.8K1
日常用得到的 Koa 优雅代码指南
为什么选择 Koa 小王:为什么选择Koa? 老王:因为 Koa 比较轻量,几乎没有内置任何的额外功能。也是因为这个原因,Koa 的灵活度是很高的,喜欢折腾的人可以尝试下 小王:又轻量又几乎没有任何额
用户3806669
2021/07/06
1.9K0
日常用得到的 Koa 优雅代码指南
Hyperledger fabric链码数据模型的探讨(1)之转账和交易
编写过一些链码的人可能会觉得是在操作一个简单的key-value数据库, 就是GetState和PutState去操作键值对,而对复杂些的一对多,多对多等实体关系和数据模型不知怎么设计。我们先从官方的例子入手一起探讨下。
Zeal
2020/11/11
1.2K0
使用JSON Schema来验证接口数据
该文介绍了如何使用JSON Schema来验证接口数据。JSON Schema是一种用于定义和验证JSON数据结构的工具。它可以定义一个JSON对象,并指定该对象中哪些字段是必须的,哪些字段是可选的,以及字段的类型和约束。使用JSON Schema可以方便地验证JSON数据是否符合预期的格式,并确保数据中的字段类型和约束符合要求。该文还介绍了如何使用Dojo Toolkit中的JSON Schema验证模块来验证JSON数据,并提供了相关的示例代码。
IMWeb前端团队
2017/12/29
2.4K0
别再手动验证数据了!Python + JSONSchema,一键搞定
在Python中,jsonschema是一个用于验证JSON数据是否符合特定格式的第三方库。它基于JSON Schema规范,允许你定义一个模式(schema),然后检查JSON数据是否符合这个模式。这对于确保数据的完整性、一致性和符合预期的结构非常有用。
小白的大数据之旅
2024/11/20
3020
前后端数据校验和接口测试就没我 JSON Schema 干不了的活!
有一天,产品甩过来一个新的需求: 山月呀,「你对数据库中的用户完善用户姓名、用户邮箱、用户手机号,其中手机号必填」。
山月
2022/02/25
7910
前后端数据校验和接口测试就没我 JSON Schema 干不了的活!
Hyperledger Fabric链码开发基础篇
https://hyperledger-fabric.readthedocs.io/en/release-1.2/chaincode4ade.html
Zeal
2020/11/11
1.3K0
JQuery 学习—JQuery Validation表单验证范例[通俗易懂]
jQuery Validato表单验证插件,它是基于jQuery类库,实现了js脚本于页面html代码的分离。你可以划分多个校验组,每个组的校验都是互不影响。对一个表单对象,你只需要写一行代码就可以轻松实现无数种(理论上)脚本控制。
全栈程序员站长
2022/07/19
2K0
Python Cerberuscerberus地狱犬 (Cerberus是一个用于Python的轻量级且可扩展的数据验证库)概述安装Cerberus用法验证规则(Validation Rules)规范
cerberus地狱犬 (Cerberus是一个用于Python的轻量级且可扩展的数据验证库) 前言 文章内容有点多,是自己学习cerberus的记录,原文,由于篇幅有限,源码的解析就没有了,源码不是
若与
2018/04/25
3.9K0
Python Cerberuscerberus地狱犬 (Cerberus是一个用于Python的轻量级且可扩展的数据验证库)概述安装Cerberus用法验证规则(Validation Rules)规范
Node.js中的关注点分离
作者 | Emeni Oghenevwede 译者 | 明知山 策划 | 丁晓昀 关键要点 关注点分离是 Node.js 的一种架构,可以确保代码的可读性、易于重构和良好的代码协作。 通过遵循关注点分离原则,你可以确保最终的系统是稳定和可维护的。 关注点分离的原则确保了组件不会重复,从而使系统更加容易维护和重构。 关注点分离原则认为,业务逻辑应该与控制器分离。这简化了控制器的开发和测试用例的编写。 关注点分离原则有助于提升代码的可重用性。这样可以很容易地找到故障的来源以及如何将其从整个系统中隔
深度学习与Python
2023/03/29
6K0
Node.js中的关注点分离
angularjs输入验证[通俗易懂]
原文 http://www.cnblogs.com/woshinidezhu/p/Form-validation-with-AngularJS.html
全栈程序员站长
2022/09/15
1.5K0
jQuery.validationEngine.js学习[通俗易懂]
看一下结构,还是比较清晰的。jQuery的dom对象直接调用就行了,下面我拿jQuery官方上的一个例子来说明
全栈程序员站长
2022/11/09
4.1K0
jQuery.validationEngine.js学习[通俗易懂]
推荐阅读
相关推荐
校验数据结构调研
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验