本文章來給大家介紹在php中生成和獲取XML格式數據代碼,生成xml我們使用DOMDocument,讀取xml我們使用XMLReader即可,下面我分別給大家介紹生成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打印下數據測試。 www.it165.net
接著,建立xml,循環數組,將數據寫入到xml對應的節點中。
$doc = new DOMDocument('1.0', 'utf-8'); // 聲明版本和編碼$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 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 = "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個子節點存在的。
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答