XML是一种数据存储、交换、表达的标准:
- 存储:优势在于半结构化,可以自定义schema,相比关系型二维表,不用遵循第一范式(可以有嵌套关系);
- 交换:可以通过schema实现异构数据集成;
- 表达:本身就可以作为阅读文档,当然还可以使用XSLT之类的进行解析和再显示。
- 交换:可以通过schema实现异构数据集成;
- 表达:本身就可以作为阅读文档,当然还可以使用XSLT之类的进行解析和再显示。
缺点是schema验证复杂,相比后来的json等格式,相对冗余。
下面的是利用php对xml文件进行CURD操作:
xml文件的格式为:
<?xml version="1.0" encoding="utf-8"?>
<config>
<dbmsg type="mysql">
<host>127.0.0.1</host>
<port>3306</port>
<user>root</user>
<password>root123</password>
<db>ksuditest</db>
</dbmsg>
<env>
<testenv>测试环境</testenv>
<projectenv>正式环境</projectenv>
</env>
</config>
1、用三种方法读取xml文件内容:
<?php
/**
* Created by PhpStorm.
* User: xxx
* Date: 2016/11/28
* Time: 9:36
*/
// 使用三种方法来读取xml文件
// 封装获取某一个节点,下面节点的value
function getNodeValue($nodeName,$tagName){
return $nodeName->getElementsByTagName($tagName)->item(0)->nodeValue;
} // ---------------第一种方法-----DOM------------------------
/*
$xmlDoc = new DOMDocument();
// 加载xml文件
$xmlDoc->load('config.xml');
// 获取dbmsg节点
$dbmsg = $xmlDoc->getElementsByTagName('dbmsg')->item(0);
// 打印db的相关信息
echo 'host-->'.getNodeValue($dbmsg,'host')."<br>";
echo 'port-->'.getNodeValue($dbmsg,'port')."<br>";
echo 'user-->'.getNodeValue($dbmsg,'user')."<br>";
echo 'password-->'.getNodeValue($dbmsg,'password')."<br>";
echo 'db-->'.getNodeValue($dbmsg,'db')."<br>";
*/ // ---------------第二种方法--------XPATH---------------------
/*
$xmlDoc = new DOMDocument();
// 加载xml文件
$xmlDoc->load('config.xml');
// 实例化一个DOMXPath对象
$xpath = new DOMXPath($xmlDoc);
// 获取dbmsg节点,使用xpath来查询
$dbmsg = $xpath->query('//dbmsg')->item(0);
// 打印db的相关信息
echo 'host-->'.getNodeValue($dbmsg,'host')."<br>";
echo 'port-->'.getNodeValue($dbmsg,'port')."<br>";
echo 'user-->'.getNodeValue($dbmsg,'user')."<br>";
echo 'password-->'.getNodeValue($dbmsg,'password')."<br>";
echo 'db-->'.getNodeValue($dbmsg,'db')."<br>";
*/
// ---------------第三种方法--------SimpleXML---------------------
$sipleXml = simplexml_load_file('config.xml');
/*
echo 'db type==>'.$sipleXml->dbmsg['type']."<br>";
echo $sipleXml->dbmsg->host."<br>";
echo $sipleXml->dbmsg->port."<br>";
echo $sipleXml->dbmsg->user."<br>";
echo $sipleXml->dbmsg->password."<br>";
echo $sipleXml->dbmsg->db."<br>";
*/
// siplexml配合xpath使用
$dbmsg = $sipleXml->xpath("//dbmsg")[0];
// 打印dbmsg的数据
// 打印dbmsg的属性
echo 'db type==>'.$dbmsg['type']."<br>";
// 打印
echo $dbmsg->host."<br>";
echo $dbmsg->port."<br>";
echo $dbmsg->user."<br>";
echo $dbmsg->password."<br>";
echo $dbmsg->db."<br>";
2、向xml文件中添加:
<?php
/**
* Created by PhpStorm.
* User: xxx
* Date: 2016/11/28
* Time: 11:12
*/
$xmlDoc = new DOMDocument();
$xmlDoc->load("config.xml");
// 根目录
$config = $xmlDoc->getElementsByTagName("config")->item(0);
// 创建testenv节点
$env = $xmlDoc->createElement("env"); // 创建testenv
$testenv = $xmlDoc->createElement("testenv");
$testenv->nodeValue = '测试环境';
$env->appendChild($testenv); // 创建正式环境 projectenv
$projectenv = $xmlDoc->createElement("projectenv");
$projectenv->nodeValue = '正式环境';
$env->appendChild($projectenv); // 挂载env到config节点下
$config->appendChild($env);
// 保存xml文件
$xmlDoc->save('config.xml'); echo "add message success!";
3、更新xml文件:
<?php
/**
* Created by PhpStorm.
* User: xxx
* Date: 2016/11/28
* Time: 10:56
*/
// 更新xml节点的数据 $xmlDoc = new DOMDocument();
$xmlDoc->load("config.xml"); // 修改密码
$xpath = new DOMXPath($xmlDoc);
$pwd = $xpath->query('//password')->item(0);
$pwd->nodeValue = 'root123'; //save xml file
$xmlDoc->save("config.xml");
echo "update message success!";
4、对xml文件进行删除操作:
<?php
/**
* Created by PhpStorm.
* User: xxx
* Date: 2016/11/28
* Time: 13:54
*/
// 删除xml中的节点
$xmlDoc = new DOMDocument();
$xmlDoc->load("config.xml"); // 删除最后一个env节点
$envs = $xmlDoc->getElementsByTagName('env');
// 找到最后一个env节点
$delenv = $envs->item($envs->length-1);
// 移除delenv节点
$delenv->parentNode->removeChild($delenv); // save xml file
$xmlDoc->save("config.xml");
echo 'delete success!';