jsonschema
jsonschema
1 Json Schema 是什么?
Json Schema 是用来描述 Json 数据格式的一种描述性文件。
Json Schema 定义了一套词汇和规则,这套词汇和规则用来定义 Json 元数据,且元数据也是通过 Json 数据形式表达的。
Json 元数据定义了 Json 数据需要满足的规范,规范包括成员、结构、类型、约束等。参考链接: https://www.cnblogs.com/terencezhou/p/10474617.html
它本身就是一个 Json 文件,格式如下:
{
"type": "object",
"properties": {
"city": { "type": "string" },
"number": { "type": "number" },
"user": {
"type": "object",
"properties": {
"name" : {"type": "string"},
"age" : {"type": "number"}
}
}
}
}2 Json Schema 的用途是什么?
在接口开发中,有很多场景需要对请求的 Json 格式进行验证。
在业务逻辑加入大量的数据验证的代码,会使得代码部分有很多额外的工作。
这时候就可以将数据验证的工作交给 Json Schema Validator, 由他来统一验证请求数据格式的合法性。
这样做的好处是,将数据验证逻辑与业务逻辑解耦,有助于开发者写出更清晰、更易维护的代码。
使用 Json Schema,必须会它的格式,下面就是对它介绍。
3 怎么写 Json Schema 文件?
整体来看,Json Schema 就是一个嵌套的 Json。
他是通过分层来进行描述数据格式的。在每一层,Json Schema 相对于原始的 Json 都会多一层描述性内容。
在这些描述行文件中,可以对数据的格式作出限制
来看一个简单的例子:
可以看到,在 Schema 中,最外层先定义了这是一个 object 对象。
然后通过 properties 定义了这个对象的属性,分别是 city 和 number。
对于者两个属性,由分别进行了定义,其中 city 的数据类型是 string,number 的类型为 number。
所以看起来 Json Schema 相比于原始的 Json 就是多了一层描述,并在 properties 中具体描述字段属性。
当让,描述性的字段,不仅仅是 properties, 还有一些其他字段,比如 required 等,后面再介绍。
在来看一个嵌套 Json 的例子:
在这个例子中, user 是一个嵌套的 Json 对象。
跟前面的表述一样,对于 user 这个对象,多一层描述,然后在 properties 中,描述了具体的数据类型。
再来看一个 array 的类型的例子:
在这个例子中,user 变成了一个 array 对象,它用来存放 object 对象。
同理根据 Json Schema 的规则,在每一层都对这些数据格式进行了描述。
这篇文章,主要是对 Json Schema 进行介绍,后面会有一篇文章专门介绍复杂的 Json Schema 写法。
4 Python 中怎么使用 Json Schema Validator?
4.1 Flask 中使用 jsonschema
在 Python 中可以使用 jsonschema 包进行 Json 格式对验证。
以下代码是在 flask 中对 request 的 json 进行验证的 demo,请参考。
4.2 Butterfly 中使用 jsonschema
4.2.1 xingqiao
xingqiao job_extra
Last updated