亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP實(shí)現(xiàn)的XML操作類【XML Library】

 更新時(shí)間:2016年12月29日 11:07:20   作者:張宴  
這篇文章主要介紹了PHP實(shí)現(xiàn)的XML操作類,涉及php針對(duì)數(shù)組、xml的轉(zhuǎn)換、序列化、反序列化等相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了PHP實(shí)現(xiàn)的XML操作類。分享給大家供大家參考,具體如下:

這是一個(gè)接口程序,需要大量分析解析XML,PHP的xml_parse_into_struct()函數(shù)不能直接生成便于使用的數(shù)組,而SimpleXML擴(kuò)展在PHP5中才支持,于是逛逛搜索引擎,在老外的網(wǎng)站上找到了一個(gè)不錯(cuò)的PHP XML操作類。

一、用法舉例:

1、將XML文件解釋成便于使用的數(shù)組:

<?php
include('xml.php'); //引用PHP XML操作類
$xml = file_get_contents('data.xml'); //讀取XML文件
//$xml = file_get_contents("php://input"); //讀取POST過來的輸入流
$data=XML_unserialize($xml);
echo '<pre>';
print_r($data);
echo '</pre>';
?>

data.xml文件:

<?xml version="1.0" encoding="GBK"?>
<video>
<upload>
<videoid>998</videoid>
<name><![CDATA[回憶未來]]></name>
<memo><![CDATA[def]]></memo>
<up_userid>11317</up_userid>
</upload>
</video>

利用該XML操作類生成的對(duì)應(yīng)數(shù)組(漢字編碼:UTF-8):

Array
(
 [video] => Array
  (
   [upload] => Array
    (
     [videoid] => 998
     [name] => 回憶未來
     [memo] => def
     [up_userid] => 11317
    )
  )
)

2、將數(shù)組轉(zhuǎn)換成XML文件:

<?php
include('xml.php');//引用PHP XML操作類
$xml = XML_serialize($data);
?>

二、PHP XML操作類源代碼:

<?php
###################################################################################
# XML_unserialize: takes raw XML as a parameter (a string)
# and returns an equivalent PHP data structure
###################################################################################
function & XML_unserialize(&$xml){
 $xml_parser = &new XML();
 $data = &$xml_parser->parse($xml);
 $xml_parser->destruct();
 return $data;
}
###################################################################################
# XML_serialize: serializes any PHP data structure into XML
# Takes one parameter: the data to serialize. Must be an array.
###################################################################################
function & XML_serialize(&$data, $level = 0, $prior_key = NULL){
 if($level == 0){ ob_start(); echo '<?xml version="1.0" ?>',"\n"; }
 while(list($key, $value) = each($data))
  if(!strpos($key, ' attr')) #if it's not an attribute
   #we don't treat attributes by themselves, so for an emptyempty element
   # that has attributes you still need to set the element to NULL
   if(is_array($value) and array_key_exists(0, $value)){
    XML_serialize($value, $level, $key);
   }else{
    $tag = $prior_key ? $prior_key : $key;
    echo str_repeat("\t", $level),'<',$tag;
    if(array_key_exists("$key attr", $data)){ #if there's an attribute for this element
     while(list($attr_name, $attr_value) = each($data["$key attr"]))
      echo ' ',$attr_name,'="',htmlspecialchars($attr_value),'"';
     reset($data["$key attr"]);
    }
    if(is_null($value)) echo " />\n";
    elseif(!is_array($value)) echo '>',htmlspecialchars($value),"</$tag>\n";
    else echo ">\n",XML_serialize($value, $level+1),str_repeat("\t", $level),"</$tag>\n";
   }
 reset($data);
 if($level == 0){ $str = &ob_get_contents(); ob_end_clean(); return $str; }
}
###################################################################################
# XML class: utility class to be used with PHP's XML handling functions
###################################################################################
class XML{
 var $parser; #a reference to the XML parser
 var $document; #the entire XML structure built up so far
 var $parent; #a pointer to the current parent - the parent will be an array
 var $stack; #a stack of the most recent parent at each nesting level
 var $last_opened_tag; #keeps track of the last tag opened.
 function XML(){
   $this->parser = &xml_parser_create();
  xml_parser_set_option(&$this->parser, XML_OPTION_CASE_FOLDING, false);
  xml_set_object(&$this->parser, &$this);
  xml_set_element_handler(&$this->parser, 'open','close');
  xml_set_character_data_handler(&$this->parser, 'data');
 }
 function destruct(){ xml_parser_free(&$this->parser); }
 function & parse(&$data){
  $this->document = array();
  $this->stack = array();
  $this->parent = &$this->document;
  return xml_parse(&$this->parser, &$data, true) ? $this->document : NULL;
 }
 function open(&$parser, $tag, $attributes){
  $this->data = ''; #stores temporary cdata
  $this->last_opened_tag = $tag;
  if(is_array($this->parent) and array_key_exists($tag,$this->parent)){ #if you've seen this tag before
   if(is_array($this->parent[$tag]) and array_key_exists(0,$this->parent[$tag])){ #if the keys are numeric
    #this is the third or later instance of $tag we've come across
    $key = count_numeric_items($this->parent[$tag]);
   }else{
    #this is the second instance of $tag that we've seen. shift around
    if(array_key_exists("$tag attr",$this->parent)){
     $arr = array('0 attr'=>&$this->parent["$tag attr"], &$this->parent[$tag]);
     unset($this->parent["$tag attr"]);
    }else{
     $arr = array(&$this->parent[$tag]);
    }
    $this->parent[$tag] = &$arr;
    $key = 1;
   }
   $this->parent = &$this->parent[$tag];
  }else{
   $key = $tag;
  }
  if($attributes) $this->parent["$key attr"] = $attributes;
  $this->parent = &$this->parent[$key];
  $this->stack[] = &$this->parent;
 }
 function data(&$parser, $data){
  if($this->last_opened_tag != NULL) #you don't need to store whitespace in between tags
   $this->data .= $data;
 }
 function close(&$parser, $tag){
  if($this->last_opened_tag == $tag){
   $this->parent = $this->data;
   $this->last_opened_tag = NULL;
  }
  array_pop($this->stack);
  if($this->stack) $this->parent = &$this->stack[count($this->stack)-1];
 }
}
function count_numeric_items(&$array){
 return is_array($array) ? count(array_filter(array_keys($array), 'is_numeric')) : 0;
}
?>

PS:這里再為大家提供幾款關(guān)于xml操作的在線工具供大家參考使用:

在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson

在線格式化XML/在線壓縮XML:
http://tools.jb51.net/code/xmlformat

XML在線壓縮/格式化工具:
http://tools.jb51.net/code/xml_format_compress

XML代碼在線格式化美化工具:
http://tools.jb51.net/code/xmlcodeformat

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP針對(duì)XML文件操作技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP錯(cuò)誤與異常處理方法總結(jié)》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • php cli 小技巧

    php cli 小技巧

    很簡單,特別方便php做一些cli應(yīng)用的調(diào)試,需要的朋友可以參考下
    2013-06-06
  • PHP+jQuery實(shí)現(xiàn)自動(dòng)補(bǔ)全功能源碼

    PHP+jQuery實(shí)現(xiàn)自動(dòng)補(bǔ)全功能源碼

    前面手工寫了一個(gè)下拉自動(dòng)補(bǔ)全功能,寫的簡單,只實(shí)現(xiàn)了鼠標(biāo)選擇的功能,不支持鍵盤選擇,下面與大家分享下PHP+jQuery實(shí)現(xiàn)自動(dòng)補(bǔ)全功能
    2013-05-05
  • php微信開發(fā)之自定義菜單實(shí)現(xiàn)

    php微信開發(fā)之自定義菜單實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了php微信開發(fā)之自定義菜單實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 基于PHP服務(wù)端圖片生成縮略圖的方法詳解

    基于PHP服務(wù)端圖片生成縮略圖的方法詳解

    本篇文章是對(duì)PHP服務(wù)端圖片生成縮略圖的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • thinkphp中多表查詢中防止數(shù)據(jù)重復(fù)的sql語句(必看)

    thinkphp中多表查詢中防止數(shù)據(jù)重復(fù)的sql語句(必看)

    下面小編就為大家?guī)硪黄猼hinkphp中多表查詢中防止數(shù)據(jù)重復(fù)的sql語句(必看)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-09-09
  • PHP return語句的另一個(gè)作用

    PHP return語句的另一個(gè)作用

    這篇文章主要介紹了PHP return語句的另一個(gè)作用,在bbPress的代碼中看到的一個(gè)奇葩使用方法,需要的朋友可以參考下
    2014-07-07
  • PHP簡單操作MongoDB的方法(安裝及增刪改查)

    PHP簡單操作MongoDB的方法(安裝及增刪改查)

    這篇文章主要介紹了PHP簡單操作MongoDB的方法,簡單分析了php安裝及操作MongoDB數(shù)據(jù)庫的方法,涉及PHP針對(duì)MongoDB數(shù)據(jù)庫基本的增刪改查等操作技巧,需要的朋友可以參考下
    2016-05-05
  • PHP中Static(靜態(tài))關(guān)鍵字功能與用法實(shí)例分析

    PHP中Static(靜態(tài))關(guān)鍵字功能與用法實(shí)例分析

    這篇文章主要介紹了PHP中Static(靜態(tài))關(guān)鍵字功能與用法,結(jié)合實(shí)例形式分析了Static關(guān)鍵字功能、以及靜態(tài)屬性、靜態(tài)變量等相關(guān)使用技巧,需要的朋友可以參考下
    2019-04-04
  • php 攻擊方法之談php+mysql注射語句構(gòu)造

    php 攻擊方法之談php+mysql注射語句構(gòu)造

    由于PHP和MYSQL本身得原因,PHP+MYSQL的注射要比asp困難,尤其是注射時(shí)語句的構(gòu)造方面更是個(gè)難點(diǎn),本文主要是借對(duì)Okphp BBS v1.3一些文件得簡單分析,來談?wù)刾hp+mysql注射語句構(gòu)造方式,希望本文對(duì)你有點(diǎn)幫助。
    2009-10-10
  • 通過PHP的內(nèi)置函數(shù),通過DES算法對(duì)數(shù)據(jù)加密和解密

    通過PHP的內(nèi)置函數(shù),通過DES算法對(duì)數(shù)據(jù)加密和解密

    數(shù)據(jù)加密的基本過程就是對(duì)原來為明文的文件或數(shù)據(jù)按某種算法進(jìn)行處理,使其成為不可讀的一段代碼,通常稱為密文,使其只能在輸入相應(yīng)的密鑰之后才能顯示出本來內(nèi)容,通過這樣的途徑來達(dá)到保護(hù)數(shù)據(jù)不被非法人竊取、閱讀的目的
    2012-06-06

最新評(píng)論