什么是JSON Schema?

如果你曾经使用过XML Schema,RelaxNG或ASN.1,那么你很可能已经知道什么是JSON Schema,并且可以跳过本文的阅读。如果你是头一次听说,或者听过过这个词汇但不了解,那么你来对地方了。

要了解JSON Schema是什么,我们应该首先了解JSON是什么。

JSON代表“JavaScript Object Notation”,一种简单的互联网数据交换格式。由于JavaScript存在于绝大多数Web浏览器中,而JSON基于JavaScript而来,因此很容易在JavaScript中的得到支持。同时,它已被证明足够有用且足够简单,现在也被用于许多其他不涉及互联网数据交换的环境中。

从本质上讲,JSON建立在以下数据结构上:对象:

{ "key1": "value1", "key2": "value2" }

数组:

[ "first", "second", "third" ]

数值:

42 3.1415926

字符串:

"This is a string"

布尔:

true false

空值:

null

以上这些类型在大多数编程语言中都有接近的对照类型,但它们可能有不同的名称。

利用这些简单的数据类型,可以表示出各种结构化数据。然而,这种巨大的灵活性带来了巨大的责任,因为同样的概念可以用无数种方式表现出来。例如,你可以想象以不同方式表示有关JSON中某人的信息:

{

"name": "George Washington",

"birthday": "February 22, 1732",

"address": "Mount Vernon, Virginia, United States"

}

以及:

{

"first_name": "George",

"last_name": "Washington",

"birthday": "1732-02-22",

"address": {

"street_address": "3200 Mount Vernon Memorial Highway",

"city": "Mount Vernon",

"state": "Virginia",

"country": "United States"

}

}

以上这两种表述同样有效,但第二种显然比第一种更正式。数据记录的设计在很大程度上取决于其在应用程序中的预期用途,因此这里没有正确或错误的答案。但是,当应用程序通过API请求并期望得到一个人的JSON记录时,重要的是要确切知道该记录应该如何组织。也就是说,当我们需要知道JSON数据中预期的字段以及值的表示方式时,这就是JSON Schema的用武之地。

以下JSON Schema片段描述了上面第二个例子是如何构建的。这里我们不对其中的细节解释,但如果仔细观察,你可以看到,以上第二个例子中的JSON数据结构,以及其中各个字段的类型信息在这里得到了很清晰的说明。

{

"type": "object",

"properties": {

"first_name": {

"type": "string"

},

"last_name": {

"type": "string"

},

"birthday": {

"type": "string",

"format": "date"

},

"address": {

"type": "object",

"properties": {

"street_address": {

"type": "string"

},

"city": {

"type": "string"

},

"state": {

"type": "string"

},

"country": {

"type": "string"

}

}

}

}

}

通过“验证”针对此JSON Schema的第一个示例JSON数据,您可以看到它失败:

{

"name": "George Washington",

"birthday": "February 22, 1732",

"address": "Mount Vernon, Virginia, United States"

}

但是,第二个例子通过:

{

"first_name": "George",

"last_name": "Washington",

"birthday": "22-02-1732",

"address": {

"street_address": "3200 Mount Vernon Memorial Highway",

"city": "Mount Vernon",

"state": "Virginia",

"country": "United States"

}

}

您可能已经注意到,JSON Schema本身是用JSON编写的。它是JSON数据的规范,而不是计算机程序。它只是“描述JSON数据结构”的声明格式。这既是它的优势,也是它的弱点(和其他Schema语言类似)。它很容易简洁地描述数据的表面结构,并可被用于在程序运行时自动验证数据。但是,由于JSON Schema不能包含任意代码,因此对无法表达的数据元素之间的关系存在某些限制。因此,对于足够复杂的数据格式的任何“验证工具”可能具有两个验证阶段:一个在结构级别,另一个在语义级别。对于结构级别的检查,可以使用Schema语言。对于语义级别的检查,可能需要使用更通用的编程语言来实现。

JSON Schema在API的设计与实现中具有相当重要的作用。具备JSON Schema校验能力的API实现可以帮助对来自用户输入数据的自动校验,以及应用在各类需要在程序运行时完成校验的场景中。这可以帮助开发者以更加规范、严谨的方式来描述自己的API上承载的JSON数据,同时少写许多手工校验的程序代码。

遗憾的是,目前流行的REST API设计并不能直接使用JSON Schema带来的这种能力,这很大程度上在于,在REST API的设计理念中,API请求的参数并不是一个JSON对象,而是以资源模型的方式来描述,这使得无法使用JSON Schema来描述和自动校验这类API上传递的数据。

在灵长科技CEAMS通用企业应用接口管理系统上,系统并没有使用REST API的设计风格,而是参考了经典的SOAP协议设计,规定API的请求参数和返回结果必须是一个JSON对象或者数组,并且为开发者提供了包含JSON Schema支持的API规范设计向导,用户可以很方便地在这里设计和制定自己API上的JSON数据规范。同时,设计好的JSON Schema将在程序执行时,完成对请求和返回结果JSON数据的校验,帮助提高了API数据的安全性,并且避免了手写校验代码的繁琐。

除了用于完成JSON数据校验外,由于可以为JSON数据提供清晰、严谨的声明,JSON Schema在自动化API文档、自动化输入表单生成、JSON数据可视化等方面也有很好的应用场景。有不少开源项目提供了基于JSON Schema的自动化输入表单生成能力。CEAMS系统集成了其中知名的Angular Schema Form,用于为开发者提供的清晰、直观的API测试工具。这样的工具帮助开发者进一步简化了API测试的过程,提高了测试的效率。

json schema多种形式_什么是JSON Schema?相关推荐

  1. json schema多种形式_什么是JSON Schema?及其应用方式......

    如果你曾经使用过XML Schema,RelaxNG或ASN.1,那么你很可能已经知道什么是JSON Schema,并且可以跳过本文的阅读.如果你是头一次听说,或者听过过这个词汇但不了解,那么你来对地 ...

  2. json schema多种形式_如何快速写出Json Schema,校验Json Schema

    得到一个Json文件,如何快速的去测试呢? 难道是一个个节点的去验证吗?那显然效率太低了. 一般推荐使用Json Schema(一种Json的数据结构定义)去校验. 对于JsonSchema,有很多种 ...

  3. 易语言json置入_易语言json操作模块源码

    易语言json操作模块源码 系统结构:初始化,解析,到文本,置属性,置属性对象,置属性数值,取属性数值,取属性对象,取通用属性,取属性,成员数,加成员,取成员,取成员文本,置成员,删成员,置类型,赋值 ...

  4. idea json转为对象_数据存储—JSON

    JSON文件存储 JSON全称JavaScript Object Notation,也就是JavaScript对象标记,它通过对象和数组的组合来表示数据. 1.对象和数组 对象:在JavaScript ...

  5. java 解析 json 索引对象_怎么获取json对象的属性和值

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.易于人阅读和编写.同时也易于机器解析和生成.它基于JavaScript(Standard ECMA-262 ...

  6. 安卓大json文件解析_安卓解析 json 4种格式 全解析

    1  简单的一个  { ,,,,} 2  里面有数组 { , [{,,},{,,}],} 3 直接一个数组 4 数组里有数组 5 其他情况? 没有吧,除非json格式不规范 主代码: package ...

  7. json schema多种形式_Json Schema简介

    1. 引言 什么是Json Schema? 以一个例子来说明 假设有一个web api,接受一个json请求,返回某个用户在某个城市关系最近的若干个好友.一个请求的例子如下: { "city ...

  8. json schema多种形式_JSON Schema 简介

    在前后端分离架构下,JSON 格式被广泛用于前端的数据交互,并成为事实上的规范,但前端在编写表单的过程中,依旧对着字段和后端进行 CRUD,这其中的效率有可能提升吗?有什么规范能通用解决表单类的中后台 ...

  9. json schema多种形式_JsonSchema使用详解

    JSON Schema是一个用于验证JSON数据结构的强大工具, 我查看并学习了JSON Schema的官方文档, 做了详细的记录, 分享一下. 我们可以使用JSON Schema在后续做接口测试中做 ...

最新文章

  1. 谷歌AI乳腺癌检测超过人类,LeCun质疑引起讨论
  2. wxWidgets:wxConfig 概述
  3. 【Java字节码操作】JavaAssist的使用方式,代码示例
  4. Luogu P2735 电网【真·计算几何/Pick定理】By cellur925
  5. [转]ASP.Net篇之Session与Cookie
  6. 给正在努力的您几条建议(附开源代码)
  7. 2017-03-16 Codeforces 453A 概率期望,思维 UOJ 228(待补)
  8. 可能是全网最通俗易懂的微服务架构改造解读
  9. 【BZOJ4034】T2,树链剖分练习
  10. 通用权限管理设计 之 数据权限
  11. 为什么资源文件名以类型开头
  12. 死亡搁浅运送系统服务器,死亡搁浅订单23寻物系统服务器流程介绍-死亡搁浅订单23寻物系统服务器怎么做_牛游戏网...
  13. 艺术名家|翰墨异彩“三分书”——访知名书法家蔡爱军
  14. AUTOCAD——快速提取说明文字
  15. 绘制附带 AHT20 温湿度传感器的 stm32 电路原理图
  16. 计算机网络感知层,物联网感知层与感知节点
  17. “凸现”三围的健身运动法(图)
  18. Win10如何修改 开始菜单,并添加 磁贴
  19. Navicat Mysql 破解教程(亲测可用)
  20. 南邮 OJ 1652 翻转棋

热门文章

  1. thinkphp3.1 mysql5.6_Thinkphp3.1 跨库连接数据库。
  2. vue中动态渲染组件
  3. VC++ MSXML创建XML文件以及对XML文档解析
  4. kafka删除topic
  5. 关于path.join,path.resolve的详细介绍
  6. POJ 2187 Beauty Contest( 凸包求最远点对 )
  7. poj 2492A Bug's Life(并查集)
  8. 高可用性网络的简单配置方案(一)
  9. 使mysql查询条件区分大小写 数据库搜索中大小写敏感性
  10. CentOS7下ntp安装步骤