很多站长朋友们都不太清楚php提取xml数据,今天小编就来给大家整理php提取xml数据,希望对各位有所帮助,具体内容如下:
本文目录一览: 1、 PHP生成和获取XML格式数据 2、 如何通过PHP生成和获取XML格式数据 3、 PHP 获取XML数据 4、 怎么用php提取xml文件内容 5、 PHP读取XML数据 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=MyISAM DEFAULT 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 ) // 声明版本和编码
$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= encoding= utf ?>
<root>
<data>
<name>李王皓</name>
<sex>男</sex>
<age> </age>
</data>
…
</root>
获取XML格式数据
现在我们假设要从第三方获取学生信息 数据格式是XML 我们需要使用PHP解析XML 然后将解析后的数据显示或者写入本地数据库 而这里关键的一步是解析XML
PHP有很多中方法可以解析XML 其中PHP提供了内置的XMLReader类可以循序地浏览过xml档案的节点 你可以想像成游标走过整份文件的节点 并抓取需要的内容 使用XMLReader是高效的 尤其是读取非常大的xml数据 相对其他方法 使用XMLReader消耗内存非常少
header( Content type:text/; Charset=utf )
$url = // helloweba /demo/importXML/createXML php ;
$reader = new XMLReader() //实例化XMLReader
$reader >open($url) //获取xml
$i= ;
while ($reader >read()) {
if ($reader >nodeType == XMLReader::TEXT) { //判断node类型
$m = $i% ;
if($m== )
$name = $reader >value; //读取node值
if($m== )
$sex = $reader >value;
if($m== ){
$age = $reader >value;
$arr[] = array(
name => $name
sex => $sex
age => $age
)
}
$i++;
}
}
//print_r($arr)
lishixinzhi/Article/program/PHP/201311/21636
如何通过PHP生成和获取XML格式数据1自己拼,XML编码
<?php
header('Content-type:text/xml');
echo "<?xml version='1.0' encoding='utf-8'>";
echo "<book>";
echo "<PHP>";
echo "<name>PHP程序开发范例宝典</name>";
echo "<price 单位='元/本'>89.00</price>";
echo "<date>2007-09-01</date>";
echo "</PHP>";
echo "</book>";
?>
拼接的效果
2从数据库中查询再拼XML编码
<?php
$dsn="mysql:host=localhost;dbname=test";
try {
$pdo = new PDO($dsn,'root','passwowd'); //初始化一个PDO对象,就是创建了数据库连接对象$pdo
$query="select * from book"; //定义SQL语句
$pdo->query('set names utf8');
$result=$pdo->prepare($query); //准备查询语句
$result->execute(); //执行查询语句,并返回结果集
$arr='';
while($res=$result->fetch()){
$arr.='<PHP><id>'.$res[0].'</id><name>'.$res[1].'</name><date>'.$res[2].'</date>'.'<price>'.$res[3].'</price></PHP>';
}
echo "<?xml version='1.0' encoding='utf-8'?><book>".$arr.'</book>';
} catch (PDOException $e) {
die ("Error!: ".$e->getMessage()."<br>");
}
?>
拼接的效果
3使用ajax获取,DOM解析
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>xml</title>
</head>
<body>
<script>
function check(){
var xhr=new XMLHttpRequest();
xhr.open('GET','xml.php');
xhr.onreadystatechange=function(){
if(xhr.readyState==4 xhr.status==200){
console.log(xhr.responseText);
//初始化 DOM解析对象
var domParser = new DOMParser();
//字符串解码为对象
var xmlDoc = domParser.parseFromString(xhr.responseText,'text/xml');
//按标签名获取元素 返回数组
var elements = xmlDoc.getElementsByTagName('PHP');
//拼接html格式字符串
var str ='<tr><th>id</th><th>name</th><th>date</th><th>price</th></tr>';
for (var i=0;i<elements.length;i++){
var id=elements[i].getElementsByTagName('id')[0].firstChild.nodeValue;
var name=elements[i].getElementsByTagName('name')[0].firstChild.nodeValue;
var date=elements[i].getElementsByTagName('date')[0].firstChild.nodeValue;
var price=elements[i].getElementsByTagName('price')[0].firstChild.nodeValue;
str+= '<tr><td>'+id+'</td><td>'+name+'</td><td>'+date+'</td><td>'+price+'</td></tr>';
}
document.getElementById('table2').innerHTML=str;
}
};
xhr.send(null);
}
</script>
<button onclick="check();">点我</button>
<table id="table2" border="2" cellspacing="0">
</table>
</body>
</html>
效果
1
2
补充:
使用JSON
1数据库查询,自己拼 JSON 编码
<?php
$dsn="mysql:host=localhost;dbname=test";
try {
$pdo = new PDO($dsn,'root','password'); //初始化一个PDO对象,就是创建了数据库连接对象$pdo
$query="select * from book"; //定义SQL语句
$pdo->query('set names utf8');
$result=$pdo->prepare($query); //准备查询语句
$result->execute(); //执行查询语句,并返回结果集
$a=$arr='';
while($res=$result->fetch()){
$arr.='{"id":'.'"'.$res[0].'",'.'"name":'.'"'.$res[1].'",'.'"time":'.'"'.$res[2].'",'.'"jia":'.'"'.$res[3].'",'.'"zhe":'.'"'.$res[4].'",'.'"chu":'.'"'.$res[5].'"},';
}
echo $a="[".substr($arr,0,strlen($arr)-1)."]";
} catch (PDOException $e) {
die ("Error!: ".$e->getMessage()."<br>");
}
?>
2数据库查询,函数 JSON 编码
<?php
$dsn="mysql:host=localhost;dbname=test";
try {
$pdo = new PDO($dsn,'root','password'); //初始化一个PDO对象,就是创建了数据库连接对象$pdo
$query="select * from book"; //定义SQL语句
$pdo->query('set names utf8');
$result=$pdo->prepare($query); //准备查询语句
$result->execute(); //执行查询语句,并返回结果集
$res=$result->fetchAll();
//JSON 编码
echo json_encode($res);
} catch (PDOException $e) {
die ("Error!: ".$e->getMessage()."<br/>");
}
?>
效果
3ajax获取,JSON解析
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>JSON</title>
</head>
<body>
<script>
function check() {
var XHR = new XMLHttpRequest();
XHR.open('GET','JSON.php');
XHR.onreadystatechange = function (){
if(XHR.readyState == 4 XHR.status ==200){
var books =JSON .parse(XHR.responseText);
var books2='<tr><th>id</th><th>bookname</th><th>time</th><th>price</th><th>marker</th><th>publisher</th></tr>'
for (var i=0;i<books.length;i++){
books2+= '<tr><td>'+(books[i ].id)+'</td><td>'+(books[i ].name)+'</td><td>'+(books[i ].time)+'</td><td>'+(books[i ].jia)+'</td><td>'+(books[i ].zhe)+'</td><td>'+(books[i ].chu)+'</td></tr>';
}
document.getElementById('table2').innerHTML=books2;
}
};
XHR.send(null);
}
</script>
<input type="button" value="点我" onclick="check();">
<table id="table2" border="2" cellspacing="0"></table>
</body>
</html>
PHP 获取XML数据给个小例子:
1.直接是xml字符串
<?php
$string = <<<XML
<?xml version='1.0'?>
<document>
<title>Forty What?</title>
<from>Joe</from>
<to>Jane</to>
<body>
I know that's the answer -- but what's the question?
</body>
</document>
XML;
$xml = simplexml_load_string($string);
print_r($xml);
?>
2. xml文件的
<?php
if (file_exists('test.xml')) {
$xml = simplexml_load_file('test.xml');
print_r($xml);
} else {
exit('Failed to open test.xml.');
}
?>
怎么用php提取xml文件内容创建一个以.xml结尾的文档
内容如下:
<?xml version="1.0" encoding="utf-8"?>
<class>
<student info="美女">
<name>小乔</name>
<sex>女</sex>
<age>20</age>
</student>
<student>
<name>周瑜</name>
<sex>男</sex>
<age>25</age>
</student>
<student>
<name>hsy</name>
<sex>男</sex>
<age>21</age>
</student>
</class>
创建以.php结尾的文件:代码如下:
<?php
header('content-type:text/html;charset=utf-8');
//1、创建一个DOMDocument对象。该对象就表示 xml文件
$xmldoc = new DOMDocument();
//2、加载xml文件(指定要解析哪个xml文件,此时dom树节点就会加载到内存中)
$xmldoc->load("class.xml");
//3、目标:获取第一个学生的名字
$stu = $xmldoc->getElementsByTagName("name");//直接找到节点name
$stu1 = $stu->item(0);// item(1)时,可以取到周瑜
$sex=$xmldoc->getElementsByTagName("sex");
$sex1= $sex->item(0);
echo $sex1->nodeValue;
echo $stu1->nodeValue;
?>
结果显示为:女小乔
PHP读取XML数据编码问题,function
characterData改成如下
function
characterData($parser_instance,
$xml_data)
{
global
$name,$position;
$xml_data=iconv("utf-8","gb2312",$xml_data);//转换成gb2312
if($position)
echo
$xml_data."<br>";
if($name)
echo
$xml_data."<br>";
}
显示的那个页面也要有charset=gb2312
关于php提取xml数据的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。
查看更多关于php提取xml数据 phpxml解析的详细内容...