Home  >  Article  >  php教程  >  PHP Cookbook读书笔记 – 第12章XML

PHP Cookbook读书笔记 – 第12章XML

WBOY
WBOYOriginal
2016-06-06 19:40:391110browse

什么是XML? XML(eXtensible Markup Language)是国际标准化组织的标准通用标记语言SGML的子集。由以下规范组成: 可扩展样式语言(eXtensible Sytle Language , XSL) XML链接语言(XML Linking Language,包括Xpath、Xlink和Xpointer) XML名称空间(XML N

PHP Cookbook读书笔记 – 第12章XML什么是XML?

XML(eXtensible Markup Language)是国际标准化组织的标准通用标记语言SGML的子集。由以下规范组成:

  • 可扩展样式语言(eXtensible Sytle Language , XSL)
  • XML链接语言(XML Linking Language,包括Xpath、Xlink和Xpointer)
  • XML名称空间(XML Namespace)

在PHP5之前的版本对XML的处理存在很多的问题,例如XML工具之间只具有简单的关联、每个工具不能一起协同工作等,PHP5中的新XML扩展具有下列特点:

  • 能够像一个整体一样协调工作
  • 是一个标准化的XML库:libxml2
  • 完全遵循W3C规范
  • 更有效地处理数据
  • 是你工作中合适的XML工具

HTML和XML区别与联系?

HTML和XML都是SGML的子集,所以他们有很大的相似性。下面是XML相对于HTML具有的独特性:

  • 可扩展性,用以定义需要的新标记。这对于今天的web是很有意义的
  • 结构,用于表示任意复杂程度的数据。从某种意义上说是一个小型的关系数据库
  • 校验,用以检查数据的结构正确性。通过DTD约束可以达到这一目的。
  • 媒体无关性,以多种格式发布内容。网页、手机显示的wml、其他媒体终端的显示等
  • 厂商和平台中立
  • 数据的表示与内容分离(这是与html本质区别,但现在流行的DIV+CSS设计思路与这种近似)
  • XML的元素区分大小写
  • 任何元素都需要有结束标记
  • XML只有一个根元素
  • 属性必须加上引号

一个完整的XML长什么样子?

<?xml version="1.0"?>
<shows>
    <show>
        <name>Simpsons</name>
        <channel>FOX</channel>
        <start>8:00 PM</start>
        <duration>30</duration>
    </show>
    <show>
        <name>Law & Order</name>
        <channel>NBC</channel>
        <start>8:00 PM</start>
        <duration>60</duration>
    </show>
</shows>

  

形式良好的XML文档须具备下列特征:

  • 每一个元素有一个开始和结束标记
  • 文档有且只有一个根元素,其他的所有元素都是它的子元素
  • 正确的格式化空元素
  • 标记的大小写匹配
  • 正确的嵌套
  • 属性值必须用引号
  • 实体在引用之前必须声明
  • 实体不能循环指向自身

通过DOM生成XML

 
// 创建一个新的文档<br>$dom = new DOMDocument('1.0');
// 创建一个根元素<book>并将其添加到文档<br>$book = $dom->appendChild($dom->createElement('book'));
// 创建一个title子元素,并添加到$book中
$title = $book->appendChild($dom->createElement('title'));
// 设置title元素的文本及cover属性
$title->appendChild($dom->createTextNode('PHP Cookbook'));
$title->setAttribute('cover', 'soft');
// 创建并将author元素添加到$book中
$sklar = $book->appendChild($dom->createElement('author'));
//添加文本到author节点<br>$sklar->appendChild($dom->createTextNode('Sklar'));

$trachtenberg = $book->appendChild($dom->createElement('author'));
$trachtenberg->appendChild($dom->createTextNode('Trachtenberg'));

// 输出完美格式化的XML文档<br>$dom->formatOutput = true;
echo $dom->saveXML();</book>

输出内容如下:

<?xml version="1.0"?>
<book>
  <cover>PHP Cookbook
</cover></book>

用PHP解析已经存在的XML文件

常用有三种方式来解析XML文件

  1. 对于简单文件采用SimpleXML
  2. 对于复杂的XML文件采用DOM扩展来实现
  3. 对于大型XML文件采用XMLReader扩展来实现

XML示例文件如下(address-book.xml):

<?xml version="1.0"?>
<address-book>
    <person id="1">
        <!--David Sklar-->
        <firstname>David</firstname>
        <lastname>Sklar</lastname>
        <city>New York</city>
        <state>NY</state>
        <email>sklar@php.net</email>
    </person>

    <person id="2">
        <!--Adam Trachtenberg-->
        <firstname>Adam</firstname>
        <lastname>Trachtenberg</lastname>
        <city>San Francisco</city>
        <state>CA</state>
        <email>amt@php.net</email>
    </person>
</address-book>

  

通过SimpleXML方式:

$sx = simplexml_load_file('address-book.xml');

foreach ($sx->person as $person) {
    $firstname_text_value = $person->firstname;
    $lastname_text_value = $person->lastname;

    print "$firstname_text_value $lastname_text_value\n";
}

通过DOM扩展:

 
$dom = new DOMDocument;
$dom->load('address-book.xml');

foreach ($dom->getElementsByTagname('person') as $person) {
    $firstname = $person->getElementsByTagname('firstname');
    $firstname_text_value = $firstname->item(0)->firstChild->nodeValue;

    $lastname = $person->getElementsByTagname('lastname');
    $lastname_text_value = $lastname->item(0)->firstChild->nodeValue;

    print "$firstname_text_value $lastname_text_value\n";
}

通过XMLReader扩展:

$reader = new XMLReader();
$reader->open('card-catalog.xml');

while ($reader->read()) {
    if ($reader->nodeType == XMLREADER::ELEMENT && $reader->localName == 'author') {
        $reader->read();
        print $reader->value . "\n";
    }
}

用XPath来查询信息

在SimpleXML和DOM扩展中都有XPath

//SimpleXml示例
$emails = $s->xpath('/address-book/preson/email');

//DOM扩展示例
$xpath = new DOMXPath($dom);
$email = $xpath->query('/address-book/preson/email');

验证XML文档是否合法

在PHP中,DOM扩展支持基于DTD,XML Schema和RelaxNG的验证,而SimpleXML则只提供了XML Schema验证。

XML内容为UTF-8格式

如果数据来源为其他格式,需要经过编码为UTF-8格式,下面是通过iconv库进行转换的示例

$utf_8 = iconv('ISO-8859-1', 'UTF-8', $iso_8859_1);

其他参考资料:《PHP高级开发技术与实例》 清华大学出版社

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn