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

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

May 25, 2016 pm 04:42 PM
php générer du 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;  
Copier après la connexion

首先,建立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 
	} 
Copier après la connexion

这个时候,数据就保存在$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(); 
Copier après la connexion

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

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

获取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); 
Copier après la connexion

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

文章地址:

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

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)