首页 >php教程 >php手册 >PHP生成XML格式数据与解析xml数据

PHP生成XML格式数据与解析xml数据

WBOY
WBOY原创
2016-05-25 16:42:042067浏览

本文章来详细的介绍一下关于PHP生成XML格式数据与解析xml数据程序代码,有需要学习的朋友可参考参考,先看xml文档,代码如下:

<?xml version="1.0" encoding="utf-8" 
<article> 
    <item> 
        <title size="1">title1</title> 
        <content>content1</content> 
        <pubdate>2009-10-11</pubdate> 
    </item> 
    <item> 
        <title size="1">title2</title> 
        <content>content2</content> 
        <pubdate>2009-11-11</pubdate> 
    </item> 
</article>

那么我们用php如何生成xml格式数据呢

方法1:使用纯粹的PHP代码生成字符串,并把这个字符串写入一个以XML为后缀的文件,这是最原始的生成XML的方法,不过有效.

PHP代码如下:

<?PHP 
$data_array = array( 
    array( 
    &#39;title&#39; => &#39;title1&#39;, 
    &#39;content&#39; => &#39;content1&#39;, 
        &#39;pubdate&#39; => &#39;2009-10-11&#39;, 
    ), 
    array( 
    &#39;title&#39; => &#39;title2&#39;, 
    &#39;content&#39; => &#39;content2&#39;, 
    &#39;pubdate&#39; => &#39;2009-11-11&#39;, 
    ) 
); 
$title_size = 1; 
$xml = "<?xml version=\"1.0\" encoding=\"utf-8\"n"; 
$xml .= "<article>\n"; 
foreach ($data_array as $data) { 
    $xml .= create_item($data[&#39;title&#39;], $title_size, $data[&#39;content&#39;], $data[&#39;pubdate&#39;]); 
} 
$xml .= "</article>\n"; 
echo $xml; 
//  创建XML单项 
function create_item($title_data, $title_size, $content_data, $pubdate_data) { 
    $item = "<item>\n"; 
    $item .= "<title size=\"" . $title_size . "\">" . $title_data . "</title>\n"; 
    $item .= "<content>" . $content_data . "</content>\n"; 
    $item .= " <pubdate>" . $pubdate_data . "</pubdate>\n"; 
    $item .= "</item>\n";
    return $item; 
} 
?>

方法2:使用DomDocument生成XML文件

创建节点使用createElement方法,创建文本内容使用createTextNode方法,添加子节点使用appendChild方法,创建属性使用createAttribute方法,代码如下:

<?PHP 
$data_array = array( 
    array( 
    &#39;title&#39; => &#39;title1&#39;, 
    &#39;content&#39; => &#39;content1&#39;, 
        &#39;pubdate&#39; => &#39;2009-10-11&#39;, 
    ), 
    array( 
    &#39;title&#39; => &#39;title2&#39;, 
    &#39;content&#39; => &#39;content2&#39;, 
    &#39;pubdate&#39; => &#39;2009-11-11&#39;, 
    ) 
); 
//  属性数组 
$attribute_array = array( 
    &#39;title&#39; => array( 
    &#39;size&#39; => 1 
    ) 
); 
//  创建一个XML文档并设置XML版本和编码。。 
$dom=new DomDocument(&#39;1.0&#39;, &#39;utf-8&#39;); 
//  创建根节点 
$article = $dom->createElement(&#39;article&#39;); 
$dom->appendchild($article); 
foreach ($data_array as $data) { 
    $item = $dom->createElement(&#39;item&#39;); 
    $article->appendchild($item); 
    create_item($dom, $item, $data, $attribute_array); 
} 
echo $dom->saveXML(); 
function create_item($dom, $item, $data, $attribute) { 
    if (is_array($data)) { 
        foreach ($data as $key => $val) { 
            //  创建元素 
            $$key = $dom->createElement($key); 
            $item->appendchild($$key); 
            //  创建元素值 
            $text = $dom->createTextNode($val); 
            $$key->appendchild($text); 
            if (isset($attribute[$key])) {  //  如果此字段存在相关属性需要设置 
                foreach ($attribute[$key] as $akey => $row) { 
                    //  创建属性节点 
                    $$akey = $dom->createAttribute($akey); 
                    $$key->appendchild($$akey); 
                    // 创建属性值节点 
                    $aval = $dom->createTextNode($row); 
                    $$akey->appendChild($aval); 
                } 
            }   //  end if 
        } 
    }   //  end if 
}   //  end function 
?>

下面我们以学生信息表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 &#39;0&#39;, 
PRIMARY KEY (`id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8;


首先,建立createXML.php文件,先连接数据库,获取数据,代码如下:

<?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( 
&#39;name&#39; => $row[&#39;name&#39;], 
&#39;sex&#39; => $row[&#39;sex&#39;], 
&#39;age&#39; => $row[&#39;age&#39;] 
); 
}
?>

这个时候,数据就保存在$arr中,你可以使用print_r打印下数据测试,接着,建立xml,循环数组,将数据写入到xml对应的节点中,代码如下:

<?php
$doc = new DOMDocument(&#39;1.0&#39;, &#39;utf-8&#39;); // 声明版本和编码 
$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[&#39;name&#39;])); 
$b->appendChild($name); 
$sex = $doc->createElement("sex"); 
$sex->appendChild($doc->createTextNode($dat[&#39;sex&#39;])); 
$b->appendChild($sex); 
$age = $doc->createElement("age"); 
$age->appendChild($doc->createTextNode($dat[&#39;age&#39;])); 
$b->appendChild($age); 
$r->appendChild($b); 
} 
echo $doc->saveXML();
?>

我们调用了PHP内置的类DOMDocument来处理与生成xml,最终生成的xml格式,代码如下:

73986290fadb154132fde247819198db 

1d029f6197b5a3eb8a3fdf0a088ddf55 

8a11bc632ea32a57b3e3693c7987c420李王皓df406f776eecbaf16b62325323196f14 

5eb1976fb331069a3f8db095dc061fe9男1a8de34dd1983c867de2a59ae06cc634 

ff4fd28be6111b38109cb452b13c2daa213c0b87764dcdf259cfde0951b2fe8a3a 

07b4fdd0136efc154b4b9d48cfcbbb9d 

… 

c02ae4fdd442eb2210bebb17feeb95b4 

获取XML格式数据

现在我们假设要从第三方获取学生信息,数据格式是XML,我们需要使用PHP解析XML,然后将解析后的数据显示或者写入本地数据库,而这里关键的一步是解析XML.

PHP有很多中方法可以解析XML,其中PHP提供了内置的XMLReader类可以循序地浏览过xml档案的节点,你可以想像成游标走过整份文件的节点,并抓取需要的内容,使用XMLReader是高效的,尤其是读取非常大的xml数据,相对其他方法,使用XMLReader消耗内存非常少,代码如下:

<?php
header("Content-type:text/html; Charset=utf-8");
$url = "你的xml路么";
$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(
                &#39;name&#39; => $name,
                &#39;sex&#39; => $sex,
                &#39;age&#39; => $age
            );
        }
        $i++;
    }
}
//print_r($arr);
?>

为了将数据name,sex和age分开,我们使用$i%3来判断取模,因为在获取的xml中,节点data下的信息是以3个子节点存在的.

生成与读取xml文档的方法有很多,下面我就不介绍了,大家可参考相关的文档.


本文地址:

转载随意,但请附上文章地址:-)

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn