『壹』 php怎麼接收xml數據存入資料庫
用PHP的XML解析
$xml=simplexml_load_string($data);//創建SimpleXML對象
print_r($xml);//輸出XML
『貳』 php如何接收xmlhttp post過來的xml數據
您好:
既然是POST過來的,那麼直接使用$_POST['param'];即可獲取,param就是對方POST過來的時候的變數名稱,請試試。
『叄』 PHP讀寫XML文件技巧
常用 如下 幾行
header("content type:text/; charset=utf "); //指定PHP使用UTF 編碼 $xml = simplexml_load_file("example xml"); //讀取xml文件 $newxml = $xml >雀明廳asXML(); //標准化$xml $fp = fopen("newxml xml" "w"); //新建xml文件 fwrite($fp $newxml); //寫入槐搏 xml文件 fclose($fp);
PHP可以方便的生成和讀取XML文件 PHP主要通過DOMDocument DOMElement和DOMNodeList來完成XML的讀取與寫入操作的 下面就簡要說明下如何使用這些類
一.生成XML文件 對於一個如下XML文件
[] <?xml version=" " encoding="UTF "?> <article> <title>PHP訪問MySql資料庫 初級篇</title> <link> </article> <?xml version=" " encoding="UTF "?> <article> <title>PHP訪問MySql資料庫 初級篇</title> <link> </article> 我們來看看如何用PHP來生成
首先new一個DOMDocument對象並設置編碼格式
$dom = newDOMDocument( UTF );
$dom >formatOutput= true;
再創建<article>結點和<title>結點
$rootelement =$dom >createElement("article");
$title =$dom >createElement("title" "PHP訪問MySql資料庫 初級篇");
然後創建帶文本內容的<link>結點
$link =$dom >createElement("link" "
也可以先生成<link>結點再為其添加文本內容
$link = $dom >createElement("link");
$linktext =$dom >createTextNode( );
$link >appendChild($linktext);
然後將<title>和<link>結點加入到<article>結點中去
$rootelement >appendChild($title);
$rootelement >appendChild($link);
最後將<article>結點加入到DOMDocument對象中
$dom >appendChild($rootelement);
這樣一個完整的XML就生成完畢了 再整出整個XML
echo $dom >saveXML() ;
saveXML()也可以只輸入部分XML文本 如echo $dom >saveXML($link);就只會輸出<link>結點 <link>
下面再給出一個完整的PHP中數據內容輸出到XML文件的例子頃隱 該例子會對將一個PHP數組輸出到XML文件中
[php] <?php //將數組輸出到XML文件中 // by MoreWindows( $article_array = array( "第一篇" => array( "title"=>"PHP訪問MySql資料庫 初級篇" "link"=>" ) "第二篇" => array( "title"=>"PHP訪問MySql資料庫 中級篇 Smarty技術" "link"=>" ) "第三篇" => array( "title"=>"PHP訪問MySql資料庫 高級篇 AJAX技術" "link"=>" ) ); $dom = new DOMDocument( UTF ); $dom >formatOutput = true; $rootelement = $dom >createElement("MoreWindows"); foreach ($article_array as $key=>$value) { $article = $dom >createElement("article" $key); $title = $dom >createElement("title" $value[ title ]); $link = $dom >createElement("link" $value[ link ]); $article >appendChild($title); $article >appendChild($link); $rootelement >appendChild($article);
} $dom >appendChild($rootelement); $filename = "D:test xml"; echo XML文件大小 $dom >save($filename) 位元組 ; ?> <?php //將數組輸出到XML文件中 // by MoreWindows( $article_array = array( "第一篇" => array( "title"=>"PHP訪問MySql資料庫 初級篇" "link"=>" ) "第二篇" => array( "title"=>"PHP訪問MySql資料庫 中級篇 Smarty技術" "link"=>" ) "第三篇" => array( "title"=>"PHP訪問MySql資料庫 高級篇 AJAX技術" "link"=>" ) ); $dom = new DOMDocument( UTF ); $dom >formatOutput = true; $rootelement = $dom >createElement("MoreWindows"); foreach ($article_array as $key=>$value) { $article = $dom >createElement("article" $key); $title = $dom >createElement("title" $value[ title ]); $link = $dom >createElement("link" $value[ link ]); $article >appendChild($title); $article >appendChild($link); $rootelement >appendChild($article); } $dom >appendChild($rootelement); $filename = "D:test xml"; echo XML文件大小 $dom >save($filename) 位元組 ; ?> 運行該PHP會在D盤上生成test xml文件(Win + XAMPP + IE 測試通過)
二.讀取XML文件 以讀取前文中生成的D:test xml為例
[php] <?php //讀取XML文件 // by MoreWindows( $filename = "D:test xml"; $article_array = array(); $dom = new DOMDocument( UTF ); $dom >load($filename); //得到<article>結點 $articles = $dom >getElementsByTagName("article"); echo <article> 結點個數 $articles >length; foreach ($articles as $article) { $id = $article >getElementsByTagName("id") >item( ) >nodeValue; $title = $article >getElementsByTagName("title") >item( ) >nodeValue; $link = $article >getElementsByTagName("link") >item( ) >nodeValue; $article_array[$id] = array( title =>$title link =>$link); } //輸出結果 echo "<pre>"; var_mp($article_array); echo "</pre>"; ?> <?php //讀取XML文件 // by MoreWindows( $filename = "D:test xml"; $article_array = array();
$dom = new DOMDocument( UTF ); $dom >load($filename);
//得到<article>結點 $articles = $dom >getElementsByTagName("article"); echo <article> 結點個數 $articles >length; foreach ($articles as $article) { $id = $article >getElementsByTagName("id") >item( ) >nodeValue; $title = $article >getElementsByTagName("title") >item( ) >nodeValue; $link = $article >getElementsByTagName("link") >item( ) >nodeValue; $article_array[$id] = array( title =>$title link =>$link); }
lishixin/Article/program/PHP/201311/20909
『肆』 PHp怎麼獲取網路傳過來的xml文件
<?php
$xml_string=file_get_contents("php://input");
$xml_string=trim($xml_string);
$xml_object=simplexml_load_string($xml_string);
$xml_arr=get_object_vars($xml_object);
只要別人訪問你這個文件傳遞xml。你就能獲取其中的信息了。
『伍』 php 讀取xml文件的方法
首先 你的 XML文件代碼錯了, 要改下<user> 缺少斜杠 應該是</user>
XML文件代碼:
<?xml version="1.0" encoding="utf-8"?>
<users>
<user id="1" title="哈哈">張三</user>
<user id="2" title="呵呵">李四</user>
</users>
PHP文件代碼:
<?php
// 首先要建一個DOMDocument對象
$xml = new DOMDocument();
// 載入Xml文件
$xml->load('1.xml');
// 獲取所有的user標簽
$user = $xml->getElementsByTagName('user');
// 獲取user標簽的數量
$len = $user->length;
$data = array();
for($i=0;$i<$len;$i++) {
$data[$i] = array();
//第1個 item 代表 user標簽的 順序 第2個 item 代表屬性的順序
$data[$i]['id'] = $user->item($i)->attributes->item(0)->nodeValue;
$data[$i]['title'] = $user->item($i)->attributes->item(1)->nodeValue;
$data[$i]['value'] = $user->item($i)->nodeValue;
}
print_r($data);
?>
『陸』 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)
lishixin/Article/program/PHP/201311/21636