JSON 校验综述

  • Jonathan Allen
  • 赵震一

2013 年 4 月 18 日

话题:.NET架构

我们所创建的任何“灵活”或“可扩展的”文件格式,迟早都会因为校验的问题而遭受开发者们的抱怨。在处理校验问题方面有着很多的工具,但是通常可以将它们归为以下几类:

  • 判断数据是否已被正确格式化
  • 手动检查形式有误的数据并尝试纠正
  • 手动检查形式有误的数据并将有误数据丢弃
  • 自动检查形式有误的数据

这篇文章的目的并非为了讨论这些选项,而是对自动校验方面的可用工具包进行了一些总结。

JSON Schema

JSON Schema 是一个建议标准,并且已得到了 17 个不同项目的支持。它可在 JavaScript、Java、Python、 Ruby、Perl、 PHP、.NET、ActionScript、C、 Haskell 和 Erlang 等技术中使用。这种格式比 VeriJSON 更加复杂,模式与实际数据之间的关系几乎很难找到相似之处。然而它的功能也更加广泛,具备支持范围检查的数字、可限制的列表以及在列表中防止重复条目等功能。它同样还支持对其他模式的引用,允许你将大型模式拆分成一个个较小的模式。

Atdgen

Atdgen 对 OCaml 提供了 JSON 的序列化与反序列化支持。JSON 的模式是使用 atd 文件创建的。通过一个代码生成器运行这些文件就可以生成 OCaml 类文件和匹配的对象 /JSON 转换器。在 Atdgen 中,校验是在反序列化过程中进行的。

atd 文件中的校验规则是开放的,开发者可以直接在 atd 文件中注入任意他们想要的 OCaml 代码。它支持对二级模式文件的引用。

Atdgen 基于开源许可可用。

DataContractJsonSerializer

DataContractJsonSerializer基于 WCF 的 DataContractSerializer,它使用类定义和数据契约属性来确定一个 JSON 文件应该如何进行校验和最终的反序列化。这种方式适合于基本的任务,但是也明显地显现出了性能问题,在字典方面也存在难点。它的校验非常受限于基本结构。

Json.NET

James Newton-King 的 Json.NET 是迄今为止最具综合性的 JSON 序列化和反序列化工具。像 DataContractJsonSerializer 一样,Json.NET 可以使用类来定义它的模式。你可以任意选择使用标准 WCF 数据契约属性或JSON.NET 的序列化属性,同时它还支持了大量的类型,包括 DataTable 和 nHibernate 实体。而就在这个月,JSON.NET 5.0 (通过 BigInteger)支持了无大小限制的整数以及以 IEnumerable 构造器方式暴露的只读集合(collection)。

JSON.NET 同样支持通过 JSON Schema 进行校验。

VeriJSON

VeriJSON 是一个依赖于基于模式匹配的 Objective-C 库。模式本身以 JSON 的方式编写。支持的类型有“number”、“string”、“bool”和“url”。字符串可以通过一个正则表达式来进行约束,而 url 则可以通过模式进行约束(例如:http,ftp)。以结构化的方式表现数组和对象,并支持可选的属性。

VeriJSON基于开源许可可用。

英文原文链接JSON Validation Roundup

.NET架构