PHP生成和获取XML格式数据的方法


Posted in PHP onMarch 04, 2016

本文实例讲述了PHP生成和获取XML格式数据的方法。分享给大家供大家参考,具体如下:

在做数据接口时,我们通常要获取第三方数据接口或者给第三方提供数据接口,而这些数据格式通常是以XML或者JSON格式传输,这里将介绍如何使用PHP生成XML格式数据供第三方调用以及如何获取第三方提供的XML数据。

生成XML格式数据

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

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']
  );
}

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

$doc = new DOMDocument('1.0', 'utf-8'); // 声明版本和编码
$doc->formatOutput = true;
$r = $doc->createElement_x("root");
$doc->appendChild($r);
foreach ($arr as $dat) {
  $b = $doc->createElement_x("data");
  $name = $doc->createElement_x("name");
  $name->appendChild($doc->createTextNode($dat['name']));
  $b->appendChild($name);
  $sex = $doc->createElement_x("sex");
  $sex->appendChild($doc->createTextNode($dat['sex']));
  $b->appendChild($sex);
  $age = $doc->createElement_x("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 = "http://www.helloweba.com/demo/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个子节点存在的。

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
php正则
Jul 07 PHP
BBS(php &amp; mysql)完整版(五)
Oct 09 PHP
php中iconv函数使用方法
May 24 PHP
php 不同编码下的字符串长度区分
Sep 26 PHP
php下通过IP获取地理位置的代码(小偷程序)
Jun 09 PHP
Windows下部署Apache+PHP+MySQL运行环境实战
Aug 31 PHP
深入array multisort排序原理的详解
Jun 18 PHP
关于php 接口问题(php接口主要也就是运用curl,curl函数)
Jul 01 PHP
PHP 伪静态技术原理以及突破原理实现介绍
Jul 12 PHP
使用openssl实现rsa非对称加密算法示例
Jan 24 PHP
Linux系统递归生成目录中文件的md5的方法
Jun 29 PHP
Yii2配置Nginx伪静态的方法
May 05 PHP
PHP使用fopen与file_get_contents读取文件实例分享
Mar 04 #PHP
PHP截取IE浏览器并缩小原图的方法
Mar 04 #PHP
zend framework中使用memcache的方法
Mar 04 #PHP
PHP结合Mysql数据库实现留言板功能
Mar 04 #PHP
实现PHP框架系列文章(6)mysql数据库方法
Mar 04 #PHP
Codeigniter中集成smarty和adodb的方法
Mar 04 #PHP
PHP常用技巧汇总
Mar 04 #PHP
You might like
网络资源
2006/10/09 PHP
PHP取进制余数函数代码
2012/01/19 PHP
PHP strstr 函数判断字符串是否否存在的实例代码
2013/09/28 PHP
PHP中__FILE__、dirname与basename用法实例分析
2014/12/01 PHP
php中switch语句用法详解
2015/08/17 PHP
php使用Jpgraph创建折线图效果示例
2017/02/15 PHP
PHP文件上传小程序 适合初学者学习!
2019/05/23 PHP
PHP使用PDO、mysqli扩展实现与数据库交互操作详解
2019/07/20 PHP
jquery判断checkbox(复选框)是否被选中的代码
2010/10/20 Javascript
Js-$.extend扩展方法使方法参数更灵活
2013/01/15 Javascript
Javascript中 关于prototype属性实现继承的原理图
2013/04/16 Javascript
JS获取Table中td值的方法
2015/03/19 Javascript
JavaScript中的toDateString()方法使用详解
2015/06/12 Javascript
总结JavaScript三种数据存储方式之间的区别
2016/05/03 Javascript
基于jquery实现智能表单验证操作
2016/05/09 Javascript
解析Javascript单例模式概念与实例
2016/12/05 Javascript
JavaScript禁止微信浏览器下拉回弹效果
2017/05/16 Javascript
js异步编程小技巧详解
2017/08/14 Javascript
jquery 键盘事件的使用方法详解
2017/09/13 jQuery
Angular2 自定义表单验证器的实现方法
2018/12/14 Javascript
jQuery实现条件搜索查询、实时取值及升降序排序的方法分析
2019/05/04 jQuery
Vue 幸运大转盘实现思路详解
2019/05/06 Javascript
UEditor 自定义图片视频尺寸校验功能的实现代码
2020/10/20 Javascript
python用10行代码实现对黄色图片的检测功能
2015/08/10 Python
浅谈python jieba分词模块的基本用法
2017/11/09 Python
Selenium鼠标与键盘事件常用操作方法示例
2018/08/13 Python
解决pyecharts在jupyter notebook中使用报错问题
2020/04/23 Python
python加密解密库cryptography使用openSSL生成的密匙加密解密
2020/02/11 Python
html5应用缓存_动力节点Java学院整理
2017/07/13 HTML / CSS
美国在线购物频道:Shop LC
2019/04/21 全球购物
银行财务部实习生的自我鉴定
2013/11/27 职场文书
出租房屋协议书
2014/09/14 职场文书
总结Pyinstaller打包的高级用法
2021/06/28 Python
python实现简单的聊天小程序
2021/07/07 Python
Python时间操作之pytz模块使用详解
2022/06/14 Python
js 实现Material UI点击涟漪效果示例
2022/09/23 Javascript