1、各自定义
- XML
扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。 XML使用DTD(document type definition)文档类型定义来组织数据;格式统一,跨平台和语言,早已成为业界公认的标准。XML是标准通用标记语言 (SGML) 的子集,非常适合 Web 传输。XML 提供统一的方法来描述和交换独立于应用程序或供应商的结构化数据。 - JSON
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。 这些特性使JSON成为理想的数据交换语言。 - JSON建构于两种结构:
“名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组 (associative array)。值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。
2.XML和JSON对比
- XML
1)应用广泛,可扩展性强,被广泛应用各种场合
2)读取、解析没有JSON快
3)可读性强,可描述复杂结构
XML的应用已经深入人心,不再赘述。 - JSON
1)结构简单,都是键值对。
2)读取、解析速度快,很多语言支持
3)传输数据量小,传输速率大大提高
4)描述复杂结构能力较弱
JavaScript、PHP等原生支持,简化了读取解析。成为当前互联网时代普遍应用的数据结构。
3、XML与JSON转换
常常会用到XML与JSON之间的转换,在这里可以更加清晰了解两者之间的区别。
- 1)常规转换
常规的节点转换,以下的案例能够直观的看到彼此之间的转换原理。
XML是节点名与值,JSON也是KEY与VALUE的键值对。这样的转换是最简单的。
XML:
<Student>张三</Student>
转为JSON:
<pre><code> { "Student": "张三" }</code></pre>
这个过程是可逆的,JSON可以很简单转为XML。
- XML节点含有属性
节点含有属性,其转换就不同了,在JSON中,XML属性也作为了JSON对象的属性,为了区别与其他的节点,这里节点名增加特殊的前缀标识"@"以标识是属性,
另外一个比较奇怪的是,节点的值,增加属性名,且有特殊前缀,“#text”。这样的处理可以使得XML与JSON的转换实现可逆操作。JSON中@开头的,转为XML时,需要生成节点属性,#text则为节点的内容。这里的转换是常用的转换器的通用做法。
以下的转换例子
XML:
<Student ID="1001">张三</Student>
- XML节点含有属性
转为JSON
<pre><code> { "Student": { "@ID": "1001", "#text": "张三" }}</code></pre>
-
3)有属性的节点生成对象
例1,无属性节点,简单的字符串数组<line> <item>name</item> <item>age</item></line>
转为JSON:
<pre><code>http://upload-images.jianshu.io/upload_images/1669146-01f7a52448a21bf9.gif?imageMogr2/auto-orient/strip
{ "line": { "item": [ "name", "age" ] }}
(http://upload-images.jianshu.io/upload_images/1669146-01f7a52448a21bf9.gif?imageMogr2/auto-orient/strip</code></pre>
例2,有属性的转为对象,无属性的则直接转为字符串
有属性节点
<pre><code><line> <item font-size="20">name</item> <item>age</item></line></code></pre>
转为JSON:
<pre><code>http://upload-images.jianshu.io/upload_images/1669146-01f7a52448a21bf9.gif?imageMogr2/auto-orient/strip
{ "line": { "item": [ { "@font-size": "20", "#text": "name" }, "age" ] }}
http://upload-images.jianshu.io/upload_images/1669146-01f7a52448a21bf9.gif?imageMogr2/auto-orient/strip
</code></pre>
- XML的节点顺序性
XML存在着节点之间的顺序,但当转为JSON后,有时顺序会被打乱。
这一点,可以解释XML与JSON的一大不同,描述结构顺序性,特别是复杂结构时,JSON没有XML清晰简单。
以下的例子,我们可以清晰看到这一点,转换不可逆。
例子:
XML:
<template> <block>天空</block> <line>地平线</line> <block>地下</block> </template>
- XML的节点顺序性
转变为JSON:
<pre><code>http://upload-images.jianshu.io/upload_images/1669146-01f7a52448a21bf9.gif?imageMogr2/auto-orient/strip
{ "template": { "block": [ "天空", "地下" ], "line": "地平线" }}
http://upload-images.jianshu.io/upload_images/1669146-01f7a52448a21bf9.gif?imageMogr2/auto-orient/strip</code></pre>
在这里,我们可以看到在JSON中,将两个block放到了一起,中间的line则放到了后面,XML原有的节点顺序就此打乱。
如果想从此JSON转为原来的XML,已经不可能。
如果非要较真,当然可以在JSON中指定具体的属性,标识其顺序或者前后节点之间的关系,但是这样做,确实增加复杂度。
4、XML的属性与元素对比
属性无法包含多重的值(元素可以)属性无法描述树结构(元素可以)属性不易扩展(为未来的变化)属性难以阅读和维护
如下的XML感觉很愚蠢:
<pre><code><message time="2014-10-01 10:10:02" to="Lucy" from="Jim" body="Don't forget the meeting!"></message></code></pre>
应该为:
<pre><code><message> <from>Jim</from> <to>Lucy</to> <time>2014-10-01 10:10:02</time> <body>Don't forget the meeting!</body> </message></code></pre>
原则:
元数据(有关数据的数据)应当存储为属性,而数据本身应当存储为元素。
- 5、建议选择原则
1)对于复杂的数据结构使用XML,简单的数据结构可采用JSON。
2)在互联网应用中数据传输中,提倡使用JSON。
3)针对前后端的差异,可以在服务端使用XML,在前端使用JSON,两者之间的转换在服务器端完成。这样可以各取所长。