php输出xml数据 phpxml

PHP输出XML到页面的3种方法详解第一种方法php输出xml数据:
复制代码
代码如下:
?php
header("Content-type:
text/xml");
echo
"?xml
version=/"1.0/"
encoding=/"UTF-8/"?";
echo
"users";
echo
"user";
echo
"name";
echo
"小小菜鸟";
echo
"/name";
echo
"age";
echo
"24";
echo
"/age";
echo
"sex";
echo
"男";
echo
"/sex";
echo
"/user";
echo
"user";
echo
"name";
echo
"艳艳";
echo
"/name";
echo
"age";
echo
"23";
echo
"/age";
echo
"sex";
echo
"女";
echo
"/sex";
echo
"/user";
echo
"/users";
?
第二种方法:
复制代码
代码如下:
?php
header("Content-type:
text/xml");
echo
"?xml
version=/"1.0/"
encoding=/"UTF-8/"?";
echo
"usersusername小小菜鸟/nameage24/agesex男/sex/userusername艳艳/nameage23/agesex女/sex/user/users";
?
第三种方法:
复制代码
代码如下:
?php
/*
用PHPphp输出xml数据的DOM控件来创建XML输出
设置输出内容的类型为xml
*/
header('Content-Type:
text/xml;');
//创建新的xml文件
$dom
=
new
DOMDocument('1.0',
'utf-8');
//建立response元素
$response
=
$dom-createElement('response');
$dom-appendChild($response);
//建立books元素并将其作为response的子元素
$books
=
$dom-createElement('books');
$response-appendChild($books);
//为book创建标题
$title
=
$dom-createElement('title');
$titleText
=
$dom-createTextNode('PHP与AJAX');
$title-appendChild($titleText);
//为book创建isbn元素
$isbn
=
$dom-createElement('isbn');
$isbnText
=
$dom-createTextNode('1-21258986');
$isbn-appendChild($isbnText);
//创建book元素
$book
=
$dom-createElement('book');
$book-appendChild($title);
$book-appendChild($isbn);
//将book作为books子元素
$books-appendChild($book);
//在一字符串变量中建立XML结构
$xmlString
=
$dom-saveXML();
//输出XML字符串
echo
$xmlString;
?
PHP生成和获取XML格式数据 在做数据接口时 我们通常要获取第三方数据接口或者给第三方提供数据接口 而这些数据格式通常是以XML或者JSON格式传输 本文将介绍如何使用PHP生成XML格式数据供第三方调用以及如何获取第三方提供的XML数据
生成XML格式数据
我们假设系统中有一张学生信息表student 需要提供给第三方调用 并有id name sex age分别记录学生的姓名 性别 年龄等信息
CREATE TABLE `student` (
`id` int( ) NOT NULL auto_increment
`name` varchar( ) NOT NULL
`sex` varchar( ) NOT NULL
`age` *** allint( ) NOT NULL default
PRIMARY KEY(`id`)
) ENGINE=MyISAMDEFAULT CHARSET=utf ;
首先 建立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( utf )// 声明版本和编码

推荐阅读