データ インターフェイスを作成する場合、通常、サードパーティのデータ インターフェイスを取得するか、サードパーティにデータ インターフェイスを提供する必要があり、これらのデータ形式は通常、XML 形式または JSON 形式で送信されます。この記事では、PHP を使用して XML 形式のデータを生成する方法を紹介します。サードパーティの呼び出しとサードパーティが提供する XML データの取得方法。
システムには、通話のために第三者に提供する必要がある学生情報テーブル学生が存在すると仮定します。学生の名前、性別、年齢などの情報をそれぞれ記録するための ID、名前、性別、年齢が含まれます。
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 であり、PHP を使用して XML を解析し、解析されたデータを表示するか、ローカル データベースに書き込む必要があります。ここで重要なステップは XML の解析です。
PHP には、XML を解析するためのメソッドが多数あります。PHP には、XML ファイルのノードを順番に参照できる組み込みの XMLReader クラスが用意されています。カーソルがファイル全体のノードを移動して、必要なコンテンツを取得することを想像できます。 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);
取得したxmlではノードデータ配下の情報が3つの子ノードとして存在するため、データ名、性別、年齢を分離するために$i%3を使用して係数を求めます。
最後に、取得したデータを出力するか、SQL ステートメントを実行してデータをローカル データベースに書き込むことができます。この手順は省略できます
。