|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
在一个团队之中或者说是在一个公司的工作岗位上,需要注重团队之间的交流合作;在学习或工作上都要端正自己的态度,要以认真的态度来对每件事,这样才能让自己更快的投入、更快的学习,而不至于浪费自己的时间。 在做数据接口时,咱们凡是要获得第三方数据接口或给第三方供应数据接口,而这些数据格局凡是是以XML或JSON格局传输,本文将引见若何利用PHP生成XML格局数据供第三方挪用和若何获得第三方供应的XML数据。
生成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打印下数据测试。
接着,创立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格局
- <?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 = "http://www.helloweba.com/demo/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个子节点存在的。
最初,你可以将获得到的数据输入或履行SQL语句,将数据写入当地数据库,此步调略过
就是管理员可以编辑,删除,回复 等功能,。加入管理员功能要加入登陆系统,慢慢你会想在线添加管理员,慢慢你会让自己的作品更漂亮些,慢慢1个完整的留言板就会出来了, |
|