现如今 Restful API 越来越流行,而 *** ON 和 XML 基本上是两种主流格式用来交换数据, *** ON和 XML 都在 Web上有完善的开放标准(RFC 7159,RFC 4825),本文将带着大家来了解下这个两种数据格式。
*** ON 是一种用于在多个应用程序之间共享数据的通信格式。 *** ON代表 JavaScript Object Notation。它基本上是键值对的 *** 。
官网:http://www.json.org/
在线校验 *** ON结构的网站:https://jsonformatter.curiousconcept.com/
*** ON 有两种数据结构:
Map,也称为对象;{….} Array;[……]也就是说所有的 *** ON 对象都是要以这些形式表示;
简单的说就是 Java 中的 Map,名称-值对的形式给出,名称和值之间用 “:” 隔开,两个Map之间用“,”隔开,一般表示形式如下:
{'key1':'value1'%2c'key2':'value2'}
下面的 Object 有 3 个键值对
{ "firstName" : "Vijay"%2c "lastName" : "Gupta"%2c "gender" : "Male" }
Map 是一个无序的“‘名称/值’对” *** 。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“%2c”(逗号)分隔。
就是普通意义上的数组,一般形式如下:
['arr1'%2c'arr2'%2c'arr3'];
下面的数组有 3 个 *** ON 对象,每个对象有 3 个键值对
[ {"name" : "Potato"%2c"stock" : "10"%2c "unit" : "kg"}%2c {"name" : "Tomato"%2c"stock" : "32"%2c "unit" : "kg"}%2c {"name" : "Onion"%2c"stock" : "27"%2c "unit" : "kg"} ]
数组是值(value)的有序 *** 。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用“%2c”(逗号)分隔。
图中的值(value)可以是双引号括起来的字符串(string)、数值(number)、true、false、 null、对象(object)或者数组(array)。这些结构可以嵌套。
字符串(string)是由双引号包围的任意数量 Unicode 字符的 *** ,使用反斜线转义。一个字符(character)即一个单独的字符串(character string)。
字符串(string)与C或者Java的字符串非常相似。
数值(number)也与C或者Java的数值非常相似。除去未曾使用的八进制与十六进制格式。除去一些编码细节。
*** ON对象也可以嵌套:
{ "id": "0001"%2c "type": "donut"%2c "name": "Cake"%2c "image": { "url": "images/0001.jpg"%2c "width": 200%2c "height": 200}%2c "thumbnail": {"url": "images/thumbnails/0001.jpg"%2c "width": 32%2c "height": 32} }
XML 是一种标记语言,也是一种用于在多个应用程序之间共享数据的通信格式,而不是 HTML,它更侧重于数据表示。
XML 被设计用来描述数据并关注数据是什么
XML 标签不需要预先定义。在 XML 中,标签和文档结构由其作者定义。通常,XML标签是自解释的,并描述它们之间的内容。
例如:
<section> <title>BOOK</title> <signing> <author name="author-1"/> <book title="book1" price="$11"/> </signing> <signing> <author name="author-2"/> <book title="book2" price="$22"/> </signing> </section>
在线校验XML结构的网站:https://codebeautify.org/xmlvalidator
某些字符不能用作 XML 标记内的内容。因此,我们用特定文本(称为实体引用)替换这些字符,以便从字面上解析这些字符
在 XML 中有 5 个预定义的实体引用:
在线格式互转: http://www.utilities-online.info/xmltojson/#.XFE-pegzaUk
XML格式:
<person> <name>zuozewei</name> <age>20</age> </person>
*** ON格式:
{ "name":"zuozewei"%2c "age":20 }
XML格式:
<section> <title>BOOK</title> <signing> <author name="author-1"/> <book title="book1" price="$11"/> </signing> <signing> <author name="author-2"/> <book title="book2" price="$22"/> </signing> </section>
*** ON格式:
{ "section": { "title": "BOOK"%2c "signing": [ { "author": { "-name": "author-1" }%2c "book": { "-title": "book1"%2c "-price": "$11" } }%2c { "author": { "-name": "author-2" }%2c "book": { "-title": "book2"%2c "-price": "$22" } } ] } }
XML是一种数据格式,同时它也是一种语言。它具有许多强大的功能,使其不仅仅是简单的数据交换数据格式。例如 XPath,属性和命名空间,XML 模式和 XSLT 等。所有这些功能都是 XML 流行的主要原因。
*** ON 并不是为了拥有这样的功能而设计的,即使它们中的一些现在正试图在 *** ON 中找到它们的位置,例如 *** ONPath。
简而言之,XML 的目的是文档标记。每当文档标记和元数据是数据的重要组成部分并且不能被删除时,总是更喜欢使用 XML。
*** ON 的目的是结构化数据交换。它通过直接表示对象,数组,数字,字符串和布尔值来实现此目的。如果不要求元数据和文档标记,始终使用 *** ON。
SentinelOne 的 SentinelLabs 去年就曾发现 Microsoft Azure 的 Defender 存在多个安全漏洞,其中部分漏洞的严重程度和影响被评为“关键”。微软已经为所有的漏洞发布了补丁,但 SentinelLabs 敦促 Azure Defender for IoT 用...
自 Windows 11 系统 2021 年 6 月发布以来,不断有各种活动欺骗用户下载恶意的 Windows 11 安装程序。虽然这种情况在过去一段时间里有所遏制,但现在又卷土重来,而且破坏力明显升级。 网络安全公司 CloudSEK 近日发现了一个新型恶意软件活动,看起来非常像是微软的官方网站...
Hackernews编译,转载请注明出处: Emotet恶意软件在中断十个月后,于15日开始运行,该软件通过多次垃圾邮件攻击向全球邮箱发送恶意文档。 Emotet是一种恶意软件感染,通过带有恶意附件的垃圾邮件攻击传播。如果用户打开附件,恶意宏或JavaScript文件,将下载Emotet DLL并...
据熟悉此事的人士透露,以色列阻止乌克兰购买NSO集团开发的飞马(Pegasus)间谍软件,因为其担心俄罗斯官员会因此而感到愤怒。在《卫报》和《华盛顿邮报》的联合调查之后,这一启示为以色列跟俄罗斯的关系有时会破坏乌克兰的进攻能力提供了新的见解–并跟美国的优先事项相矛盾。 自俄罗斯于2月24日对乌克兰...
据The Record报道,美国国土安全部(DHS)当地时间周二宣布,该机构的负责人已经启动了一项漏洞赏金计划,允许黑客报告其系统中的漏洞,以换取金钱奖励。 美国国土安全部部长亚历杭德罗·马约卡斯(Alejandro Mayorkas)在出席彭博科技峰会时说:“我们不仅关注保护和加强私营部门和整个...
Check Point Research 在近期发布的联发科芯片组的 AI 和音频处理组件中发现了一个漏洞,或被别有用心者利用于本地权限提升攻击。这意味着通过精心设计的代码,第三方应用程序可访问它不该接触到 AI 和音频相关信息 —— 理论上甚至可用于窃听。庆幸的是,该漏洞从未被发现有在野外被利用,...