search
Homephp教程php手册PHP生成和获取XML格式数据实现代码

本文章来给大家介绍在php中生成和获取XML格式数据代码,生成xml我们使用DOMDocument,读取xml我们使用XMLReader即可,下面我分别给大家介绍.

生成XML格式数据

我们假设系统中有一张学生信息表student,需要提供给第三方调用,并有id,name,sex,age分别记录学生的姓名、性别、年龄等信息.数据库SQL代码如下:

CREATE TABLE `student` (  
	  `id` int(11) NOT NULL auto_increment,  
	  `name` varchar(50) NOT NULL,  
	  `sex` varchar(10) NOT NULL,  
	  `age` smallint(3) NOT NULL default '0',  
	  PRIMARY KEY  (`id`)  
	) ENGINE=MyISAM  DEFAULT CHARSET=utf8;  

首先,建立createXML.php文件,先连接数据库,获取数据,代码如下:

include_once ("connect.php"); //连接数据库  
	 
	$sql = "select * from student";  
	$result = mysql_query($sql) or die("Invalid query: " . mysql_error());  
	while ($row = mysql_fetch_array($result)) {  
	    $arr[] = array(  
	        'name' => $row['name'],  
	        'sex' => $row['sex'],  
	        'age' => $row['age']  
	    ); //开源代码phprm.com 
	} 

这个时候,数据就保存在$arr中,你可以使用print_r打印下数据测试,接着,建立xml,循环数组,将数据写入到xml对应的节点中,代码如下:

$doc = new DOMDocument('1.0', 'utf-8');  // 声明版本和编码  
	$doc->formatOutput = true;  
	 
	$r = $doc->createElement("root");  
	$doc->appendChild($r);  
	 
	foreach ($arr as $dat) {  
	    $b = $doc->createElement("data");  
	 
	    $name = $doc->createElement("name");  
	    $name->appendChild($doc->createTextNode($dat['name']));  
	    $b->appendChild($name);  
	 
	    $sex = $doc->createElement("sex");  
	    $sex->appendChild($doc->createTextNode($dat['sex']));  
	    $b->appendChild($sex);  
	 
	    $age = $doc->createElement("age");  
	    $age->appendChild($doc->createTextNode($dat['age']));  
	    $b->appendChild($age);  
	 
	    $r->appendChild($b);  
	}  
	 
	echo $doc->saveXML(); 

我们调用了PHP内置的类DOMDocument来处理与生成xml,最终生成的xml格式,代码如下:

<?xml version="1.0" encoding="utf-8"   
	<root>   
	  <data>   
	    <name>李王皓</name>   
	    <sex>男</sex>   
	    <age>21</age>   
	  </data>  
	  ...  
	</root> 

获取XML格式数据

现在我们假设要从第三方获取学生信息,数据格式是XML,我们需要使用PHP解析XML,然后将解析后的数据显示或者写入本地数据库,而这里关键的一步是解析XML.

PHP有很多中方法可以解析XML,其中PHP提供了内置的XMLReader类可以循序地浏览过xml档案的节点,你可以想像成游标走过整份文件的节点,并抓取需要的内容,使用XMLReader是高效的,尤其是读取非常大的xml数据,相对其他方法,使用XMLReader消耗内存非常少,代码如下:

header("Content-type:text/html; Charset=utf-8");   
	$url = "importXML/createXML.php";    
	$reader = new XMLReader();  //实例化XMLReader  
	$reader->open($url); //获取xml  
	$i=1;  
	while ($reader->read()) {      
	  if ($reader->nodeType == XMLReader::TEXT) { //判断node类型  
	     $m = $i%3;  
	     if($m==1)  
	         $name = $reader->value;  //读取node值  
	     if($m==2)  
	         $sex = $reader->value;  
	     if($m==0){  
	         $age = $reader->value;  
	         $arr[] = array(  
	             'name' => $name,  
	             'sex' => $sex,  
	             'age' => $age  
	         );  
	     }  
	     $i++;  
	  }  
	}  
	//print_r($arr); 

为了将数据name,sex和age分开,我们使用$i%3来判断取模,因为在获取的xml中,节点data下的信息是以3个子节点存在的.

文章地址:

转载随意^^请带上本文地址!

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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.