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

PHP生成和获取XML格式数据实现代码

WBOY
Freigeben: 2016-05-25 16:42:00
Original
1033 Leute haben es durchsucht

本文章来给大家介绍在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;  
Nach dem Login kopieren

首先,建立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 
	} 
Nach dem Login kopieren

这个时候,数据就保存在$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(); 
Nach dem Login kopieren

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

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

获取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(  
	             &#39;name&#39; => $name,  
	             &#39;sex&#39; => $sex,  
	             &#39;age&#39; => $age  
	         );  
	     }  
	     $i++;  
	  }  
	}  
	//print_r($arr); 
Nach dem Login kopieren

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

文章地址:

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

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage