PHP封装的XML简单操作类完整实例


Posted in PHP onNovember 13, 2017

本文实例讲述了PHP封装的XML简单操作类。分享给大家供大家参考,具体如下:

xml_dom.php封装类文件:

<?php
/**
 * Class xml_dom
 *
nodeType:
1 XML_ELEMENT_NODE(元素类型)
2 XML_ATTRIBUTE_NODE
3 XML_TEXT_NODE
4 XML_CDATA_SECTION_NODE
5 XML_ENTITY_REFERENCE_NODE
6 XML_ENTITY_NODE
7 XML_PROCESSING_INSTRUCTION_NODE
8 XML_COMMENT_NODE(注释类型)
9 XML_DOCUMENT_NODE
10 XML_DOCUMENT_TYPE_NODE
11 XML_DOCUMENT_FRAGMENT_NODE
12 XML_NOTATION_NODE
 *
PHP DOMDocument操作:
属性:
Attributes   存储节点的属性列表(只读)
childNodes   存储节点的子节点列表(只读)
dataType   返回此节点的数据类型
Definition   以DTD或XML模式给出的节点的定义(只读)
Doctype   指定文档类型节点(只读)
documentElement   返回文档的根元素(可读写)
firstChild   返回当前节点的第一个子节点(只读)
Implementation   返回XMLDOMImplementation对象
lastChild   返回当前节点最后一个子节点(只读)
nextSibling   返回当前节点的下一个兄弟节点(只读)
nodeName   返回节点的名字(只读)
nodeType   返回节点的类型(只读)
nodeTypedValue   存储节点值(可读写)
nodeValue   返回节点的文本(可读写)
ownerDocument   返回包含此节点的根文档(只读)
parentNode   返回父节点(只读)
Parsed   返回此节点及其子节点是否已经被解析(只读)
Prefix   返回名称空间前缀(只读)
preserveWhiteSpace   指定是否保留空白(可读写)
previousSibling   返回此节点的前一个兄弟节点(只读)
Text   返回此节点及其后代的文本内容(可读写)
url   返回最近载入的XML文档的URL(只读)
Xml   返回节点及其后代的XML表示(只读)
方法:
appendChild   为当前节点添加一个新的子节点,放在最后的子节点后
cloneNode   返回当前节点的拷贝
createAttribute   创建新的属性
createCDATASection   创建包括给定数据的CDATA段
createComment   创建一个注释节点
createDocumentFragment   创建DocumentFragment对象
createElement   创建一个元素节点
createEntityReference   创建EntityReference对象
createNode   创建给定类型,名字和命名空间的节点
createPorcessingInstruction   创建操作指令节点
createTextNode   创建包括给定数据的文本节点
getElementsByTagName   返回指定名字的元素集合
hasChildNodes   返回当前节点是否有子节点
insertBefore   在指定节点前插入子节点
Load   导入指定位置的XML文档
loadXML   导入指定字符串的XML文档
removeChild   从子结点列表中删除指定的子节点
replaceChild   从子节点列表中替换指定的子节点
Save   把XML文件存到指定节点
selectNodes   对节点进行指定的匹配,并返回匹配节点列表
selectSingleNode   对节点进行指定的匹配,并返回第一个匹配节点
transformNode   使用指定的样式表对节点及其后代进行转换
 *
 */
class xml_dom
{
  protected $dblink; // xml连接
  protected $dbfile; // xml文件路径
  /**
   * xml文件 构造类
   * @param $db_file xml文件
   */
  public function __construct($db_file)
  {
    $this->dbfile = $db_file;
    if(!file_exists($db_file))
    {
//     die('未找到数据库文件');
      $this->dblink = new DOMDocument('1.0', 'utf-8');
      $root = $this->dblink->createElement('root');
      $this->dblink->appendChild($root);
      $this->dblink->formatOutput = true;  // xml文件保留缩进样式
      $this->dblink->save($this->dbfile);
    }
    else
    {
      $this->dblink = new DOMDocument();
      $this->dblink->formatOutput = true;
      $this->dblink->load($this->dbfile);
    }
  }
  /**
   * 遍历所有元素
   * ===============================================
   * 标准xml文件,一个元素可能有n个属性,可用自定义键[nodevalue]获取元素值
   * <?xml version="1.0" encoding="utf-8"?>
   * <table name="posts">
   *   <column name="id">1</column>
   *   <column name="title">标题一</column>
   *   <column name="content">详细内容一</column>
   * </table>
   * ===============================================
   * 简单xml文件,没有属性,键值一一对应
   * <?xml version="1.0" encoding="utf-8"?>
   * <root>
   *   <posts>
   *     <id>1</id>
   *     <title>标题一</title>
   *     <content>详细内容一</content>
   *   </posts>
   * </root>
   * @param $node
   * @return array
   */
  function getData($node=0){
    if(!$node)
    {
      $node = $this->dblink->documentElement;
    }
    $array = array();
    foreach($node->attributes as $attribute)
    {
      $key = $attribute->nodeName;
      $val = $attribute->nodeValue;
      $array[$key] = $val;
    }
    if(count($array))  // 有属性,则用[nodevalue]键代表值
    {
      $array['nodevalue'] = $node->nodeValue;
    }
    // 递归遍历所有子元素
    $node_child = $node->firstChild;
    while($node_child)
    {
      if(XML_ELEMENT_NODE == $node_child->nodeType)
      {
        $tagname = $node_child->tagName;
        $result = $this->getData($node_child);
        if(isset($array[$tagname])) // 发现有重复tagName的子元素存在,所以改用数组存储重复tagName的所有子元素
        {
          if(!is_array($array[$tagname][0]))
          {
            $tmp = $array[$tagname];
            $array[$tagname] = array();
            $array[$tagname][] = $tmp;
          }
          $array[$tagname][] = $result;
        }
        else
        {
          $array[$tagname] = $result;
        }
      }
      $node_child = $node_child->nextSibling;
    }
    if(!count($array)) // 没有子元素&没有属性=最末子元素,就返回该元素的nodeValue值
    {
      return $node->nodeValue;
    }
    return $array;
  }
  /**
   * 把array数据写到xml文件(覆盖)
   * @param $data
   */
  public function setData($data,&$node=0)
  {
    $is_root = false;
    if(!$node)
    {
      $is_root = true;
      $node = $this->dblink->documentElement;
      // 清除原数据
      $remove = array();
      $node_child = $node->firstChild;
      while($node_child)
      {
        $remove[] = $node_child;
        $node_child = $node_child->nextSibling;
      }
      foreach($remove as $r)
      {
        $node->removeChild($r);
      }
    }
    if(is_array($data))
    {
      foreach($data as $k=>$v)
      {
        if(is_array($v))
        {
          foreach($v as $r)
          {
            $item = $this->dblink->createElement($k);
            $result = $this->setData($r,$item);
            $node->appendChild($result);
          }
        }
        else
        {
          $item = $this->dblink->createElement($k);
          $value = $this->dblink->createTextNode($v);
          $item->appendChild($value);
          $node->appendChild($item);
        }
      }
    }
    else
    {
      $item = $this->dblink->createTextNode($data);
      $node->appendChild($item);
    }
    if($is_root)
    {
      $this->dblink->save($this->dbfile);  // 覆盖写入
    }
    else
    {
      return $node;
    }
  }
}

简单用法示例如下:

smp.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<root>
   <posts>
     <id>1</id>
     <title>标题一</title>
     <content>详细内容一</content>
   </posts>
   <posts>
     <id>2</id>
     <title>标题二</title>
     <content>详细内容二</content>
   </posts>
   <posts>
     <id>3</id>
     <title>标题三</title>
     <content>详细内容三</content>
   </posts>
</root>

index.php文件:

include("xml_dom.php");
$xml=new xml_dom("smp.xml");//载入xml文件
$xmlarr=$xml->getData();//读取xml文件内容
var_dump($xmlarr);

运行结果:

array(1) {
 ["posts"]=>
 array(3) {
  [0]=>
  array(3) {
   ["id"]=>
   string(1) "1"
   ["title"]=>
   string(9) "标题一"
   ["content"]=>
   string(15) "详细内容一"
  }
  [1]=>
  array(3) {
   ["id"]=>
   string(1) "2"
   ["title"]=>
   string(9) "标题二"
   ["content"]=>
   string(15) "详细内容二"
  }
  [2]=>
  array(3) {
   ["id"]=>
   string(1) "3"
   ["title"]=>
   string(9) "标题三"
   ["content"]=>
   string(15) "详细内容三"
  }
 }
}
PHP 相关文章推荐
php的一个登录的类 [推荐]
Mar 16 PHP
php计算数组不为空元素个数的方法
Jan 27 PHP
Eclipse的PHP插件PHPEclipse安装和使用
Jul 20 PHP
PHP答题类应用接口实例
Feb 09 PHP
php强制更新图片缓存的方法
Feb 11 PHP
PHP面试题之文件目录操作
Oct 15 PHP
Thinkphp批量更新数据的方法汇总
Jun 29 PHP
PHP简单实现冒泡排序的方法
Dec 26 PHP
详解PHP5.6.30与Apache2.4.x配置
Jun 02 PHP
修改yii2.0用户登录使用的user表为其它的表实现方法(推荐)
Aug 01 PHP
如何让PHP编码更加好看利于阅读
May 12 PHP
PHP获取php,mysql,apche的版本信息及更多服务器信息
Mar 09 PHP
PHP开发中解决并发问题的几种实现方法分析
Nov 13 #PHP
三个思路解决laravel上传文件报错:413 Request Entity Too Large问题
Nov 13 #PHP
kindeditor 加入七牛云上传的实例讲解
Nov 12 #PHP
Thinkphp5 微信公众号token验证不成功的原因及解决方法
Nov 12 #PHP
PHP 断点续传实例详解
Nov 11 #PHP
PHP+AJAX 投票器功能
Nov 11 #PHP
PHP实现双链表删除与插入节点的方法示例
Nov 11 #PHP
You might like
如何利用php array_multisort函数 对数据库结果进行复杂排序
2013/06/08 PHP
PHP也能干大事之PHP中的编码解码详解
2015/04/20 PHP
老司机传授Ubuntu下Apache+PHP+MySQL环境搭建攻略
2016/03/20 PHP
Windows平台实现PHP连接SQL Server2008的方法
2017/07/26 PHP
javascript编程起步(第六课)
2007/02/27 Javascript
js关闭父窗口时关闭子窗口
2013/04/01 Javascript
JS获取url链接字符串 location.href
2013/12/23 Javascript
html文档中的location对象属性理解及常见的用法
2014/08/13 Javascript
JavaScript设计模式之单件模式介绍
2014/12/28 Javascript
详解jQuery中的事件
2016/12/14 Javascript
详解angular中通过$location获取路径(参数)的写法
2017/03/21 Javascript
jQuery+PHP+Mysql实现抽奖程序
2020/04/12 jQuery
AngularJS实现进度条功能示例
2017/07/05 Javascript
node实现简单的反向代理服务器
2017/07/26 Javascript
vue使用keep-alive实现数据缓存不刷新
2017/10/21 Javascript
小程序实现多选框功能
2018/10/30 Javascript
小程序云函数调用API接口的方法
2019/05/17 Javascript
跟老齐学Python之有点简约的元组
2014/09/24 Python
python3 pillow生成简单验证码图片的示例
2017/09/19 Python
Python3实现发送QQ邮件功能(文本)
2017/12/15 Python
完美解决在oj中Python的循环输入问题
2018/06/25 Python
python实现石头剪刀布小游戏
2021/01/20 Python
[机器视觉]使用python自动识别验证码详解
2019/05/16 Python
tensorflow实现残差网络方式(mnist数据集)
2020/05/26 Python
Python实现查找数据库最接近的数据
2020/06/08 Python
Spartoo芬兰:欧洲最大的网上鞋店
2016/08/28 全球购物
如何利用find命令查找文件
2016/11/18 面试题
语文高效课堂实施方案
2014/05/03 职场文书
初婚未育证明样本
2014/10/24 职场文书
2014最新预备党员思想汇报范文:中国梦,我的梦
2014/10/25 职场文书
党的群众路线教育实践活动制度建设计划方案
2014/10/31 职场文书
证劵公司反洗钱宣传活动总结
2015/05/08 职场文书
毕业酒会致辞
2015/07/29 职场文书
幼儿园迎新生欢迎词
2015/09/30 职场文书
mysql字符串截取函数小结
2021/04/05 MySQL
CKAD认证中部署k8s并配置Calico插件
2022/03/31 Servers