ホームページ  >  記事  >  php教程  >  PHPを使用してXML形式のデータを生成・取得する

PHPを使用してXML形式のデータを生成・取得する

WBOY
WBOYオリジナル
2016-06-21 08:51:20872ブラウズ

データ インターフェイスを作成する場合、通常、サードパーティのデータ インターフェイスを取得するか、サードパーティにデータ インターフェイスを提供する必要があり、これらのデータ形式は通常、XML 形式または JSON 形式で送信されます。この記事では、PHP を使用して XML 形式のデータを生成する方法を紹介します。サードパーティの呼び出しとサードパーティが提供する 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形式のデータを取得

ここでは、サードパーティから学生情報を取得すると仮定します。データ形式は 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 ステートメントを実行してデータをローカル データベースに書き込むことができます。この手順は省略できます



声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。