#试用# #nodejs# Joi库进行入参校验

本文介绍了如何使用Joi库在Node.js中进行数据校验。从Joi的基本概念、安装、试用环境到具体的应用场景,如字符串参数校验、body校验、多参数校验、二选一及伴随条件校验等,详细展示了Joi的强大功能。通过实例代码演示了不同校验规则的效果,帮助读者快速上手Joi。
摘要由CSDN通过智能技术生成

Joi是什么?

官方文档描述是:joi lets you describe your data using a simple, intuitive, and readable language.
简单理解就是:可以简单直接描述你的数据模型的语言。
所以重点是描述,然后校验很简单。
官方文档地址:https://joi.dev/api/?v=17.4.0

安装

在项目目录里执行 npm i joi

试用环境

@google-cloud/functions-framework

简单试用

对一个字符串型参数进行校验
代码如下:

const Joi = require('joi');
const schema = Joi.object({
username: Joi.string()
  .alphanum()
  .min(3)
  .max(30)
})

exports.helloWorld = (req, res) => {
  const { error, value } = schema.validate(req.query)
  if (error) {
    return res.status(422).json({ error: error })
  }
  res.send('Hello, World') 
}

效果如下:
访问 http://localhost:8080/
返回 Hello, World
访问 http://localhost:8080/?username=aaaa
返回 Hello, World
访问 http://localhost:8080/?username=aa
返回

{
    "error": {
        "_original": {
            "username": "aa"
        },
        "details": [
            {
                "message": "\"username\" length must be at least 3 characters long",
                "path": [
                    "username"
                ],
                "type": "string.min",
                "context": {
                    "limit": 3,
                    "value": "aa",
                    "label": "username",
                    "key": "username"
                }
            }
        ]
    }
}

访问 http://localhost:8080/?username=aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
返回

{
    "error": {
        "_original": {
            "username": "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
        },
        "details": [
            {
                "message": "\"username\" length must be less than or equal to 30 characters long",
                "path": [
                    "username"
                ],
                "type": "string.max",
                "context": {
                    "limit": 30,
                    "value": "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
                    "label&
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
nodejs 中的 joi 是一个数据验证,它可以用于验证请求参数、表单数据等。使用 joi 可以方便地定义验证规则,并且可以自动进行验证,如果验证失败,joi 会返回详细的错误信息。 下面是一个使用 joi 进行参数验证的示例: ```javascript const Joi = require('joi'); const schema = Joi.object({ username: Joi.string().alphanum().min(3).max(30).required(), password: Joi.string().pattern(new RegExp('^[a-zA-Z0-9]{3,30}$')), repeat_password: Joi.ref('password'), access_token: [ Joi.string(), Joi.number() ], birth_year: Joi.number().integer().min(1900).max(2013), email: Joi.string().email({ minDomainSegments: 2, tlds: { allow: ['com', 'net'] } }) }).with('username', 'password').xor('password', 'access_token').with('password', 'repeat_password'); const result = schema.validate({ username: 'abc', birth_year: 1994 }); console.log(result); ``` 在上面的示例中,我们定义了一个包含多个字段的对象,并使用 joi 定义了每个字段的验证规则。例如,我们要求 username 字段必须是一个长度在 3 到 30 之间的字母数字字符串,而 password 字段必须是一个长度在 3 到 30 之间的字母数字字符串,并且必须与 repeat_password 字段相同。 当我们调用 `schema.validate` 方法时,joi 会自动验证传入的对象是否符合定义的规则,并返回一个包含验证结果的对象。如果验证成功,该对象的 `error` 属性为 `null`,否则为一个包含详细错误信息的对象。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值