好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>CMS系统>Dedecms
<tfoot draggable='sEl'></tfoot>

php提取xml数据 phpxml解析

很多站长朋友们都不太清楚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解析的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did175918
更新时间:2023-04-19   阅读:44次

上一篇: php跳转语句和特点 php location跳转语句怎么写

下一篇:php支持ssl php是否支持多线程

相关资讯

最新资料更新

  • 1.DEDECMS会员信息在个人模板info和index的调用问题
  • 2.dede的sql语句调用方法使用示例
  • 3.dedecms批量替换文章中超链接的方法
  • 4.织梦不能上传jpg格式的图片怎么办如何解决
  • 5.dedecms织梦模板中plus文件作用介绍及安全设置详解
  • 6.织梦DEDECMS文章页调用文章浏览次数优化调用代码
  • 7.dedecms实现自动打包文章中图片并下载的方法
  • 8.dedecms返回列表页功能的标签代码
  • 9.织梦DedeCMS在实现中英文导航功能方法步骤
  • 10.DEDE集成百度搜索谷歌搜索站内全站搜索站内按栏目搜索等功能的搜索栏
  • 11.dedecms搜索结果页实现按频道模型显示不同结果模板的方法
  • 12.修改dedecms文章标题长度限制的方法
  • 13.详解DEDECMS后台会员消费记录人性化时间显示不准的解决方法
  • 14.dedecms织梦自定义文件名之用拼音或英文标题的方法
  • 15.dedecms自定义内容模型在首页、列表页及内容调用标签的方法
  • 16.织梦CMS提示DedeTag Engine Create File False错误的解决办法总结
  • 17.dedecms如何把文章批量设为未审核的办法
  • 18.Dedecms文章标题及文章摘要长度修改的方法
  • 19.Dedecms中常用数据调用的sql语句汇总
  • 20.织梦dedecms系统后台安全提示去除方法

CopyRight:2016-2025好得很程序员自学网 备案ICP:湘ICP备09009000号-16 http://haodehen.cn
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]