1. XML の概要 XML (Extensible Markup Language) は、主に Web アプリケーションとサーバー間の簡単な対話、データの保存、使用に使用されます。 XML 標準を使用してエンコードされたデータは、人間やコンピューターが簡単に解釈できる意味と構造を持っています。 XML データはプラットフォームやアプリケーションに依存しません。言うまでもなく、このこと自体が XML をインターネットにとって理想的なデータ交換形式にしています (実際、XML はまさにこの目的のために開発されました)。最近、ブロードバンド接続の成長と、あらゆる媒体でデータを共有するアプリケーションに対する消費者の需要により、XML Web サービスとアプリケーションがますますリッチになってきています。 XML は、インターネット上の豊富なデータを記述するという組織的な問題を解決するために発明されました。これまでのところ、この問題は HTML を賢く使用することで部分的にしか解決できません。 以下は XML ドキュメントの例です: プログラム コード
コードをコピー コードは次のとおりです:
私の家 pm <ゲスト>ジョン・ブログ名前> <アイテム>フォスターズアイテム> <アイテム>傘< /item> - Bombay Mix
HTML のように見えると仮定できます。 HTML は SGML アプリケーションであり、XML はそのサブセットです。ただし、類似点には、類似したラベル区切り文字があることも含まれます。 上記の XML フラグメントを見るだけで、データが多数のゲストを含むパーティーを記述しており、各ゲストが項目に対応していることがわかります。データを説明するために使用されるラベル名はすべて作成者によって選択されます。すべての XML 標準では、データに一貫性があり、データの記述に使用されるタグが適切な形式である必要があります。文書型宣言 (DTD) または XML スキーマを使用して、データの整合性をさらに強化できます。ただし、簡単にするために、この記事ではプレーン XML のみを使用します。 2. XML アプリケーション
これまで、XML を使用してあらゆる種類のデータを記述する方法を見てきました。実際、XML は現在、多くの Web アプリケーションで広く使用されています。以下に有名なアプリケーションの説明を示します。
・ XHTML - これは最も広く使用されている XML アプリケーションの 1 つです。これは HTML に基づく SGML に似ており、Web ページ上でデータがどのように表示されるかを記述するために使用されます。 XHTML は DTD を使用して、すべてのドキュメントが標準に準拠していることを確認します。 XHTML の登場により、Web プログラマにとって開発は若干容易になりましたが、CSS および XHTML 標準と完全に互換性のある Web ブラウザはまだ登場していません。
· XML-RPC - リモート プロシージャ コール (RPC)。分散アプリケーションでリモート コンピュータ上のプロシージャを呼び出すために使用されます。 XML-RPC は、XML を使用してプロシージャ呼び出しに関する情報をエンコードし、HTTP を使用してそれを受信側コンピューターに送信します。プロシージャの戻り値は XML で再度エンコードされ、HTTP 接続を使用して呼び出し元のコンピュータに送り返されます。
· RSS - Really Simple Syndication/Rich Site Summary。特別なアプリケーションを使用して Web サイトのコンテンツ (ニュース、記事、株価、リンクなど) を集約するために使用される方法です。アグリゲータ)は、ユーザーの PC 上の RSS フィードを定期的に更新します。この RSS データは XML を使用してエンコードされて送信されます。 ・AJAX - Web 開発者が Web ブラウザーで実行される機能豊富なイベント駆動型 Web アプリケーションを作成できるようにする非同期 JavaScript および XML。このうち JavaScript は、XML エンコードされたデータをサーバー側スクリプトに送信する (またはサーバー側から XML エンコードされたデータを受信する) ために使用され、すべてのページ コンテンツを更新せずに部分的なリアルタイム ページ更新を可能にします。
上記は、XML の可能なアプリケーションのほんの一部です。今後の記事では、これらのアプリケーションを PHP で使用する方法を分析します。
3. PHP での XML の使用
PHP 5.0 以降、PHP が XML と対話するために使用できるオプションが大幅に増加しました。 PHP バージョン 4 が提供できるのは、不安定で w3c と互換性のない DOM XML 拡張機能です。
以下では、XML との対話を可能にする PHP 5 が提供する 3 つのメソッド (DOM、シンプル XML、XPath) に焦点を当てます。可能な場合は、それぞれのアプローチに最適な条件とデータを提案します。すべてのサンプル コードでは、XML データ ソースを使用して、図書館とそこに含まれる書籍を記述します。
プログラムコード
コードをコピー
コードは次のとおりです:
Web Development Database Programming PHP Java Apache 2 Peter Wainwright Wrox 1 Advanced PHP Programming George Schlossnagle Developer Library 1 3 Visual FoxPro 6 - Programmers Guide Eric Stroo Microsoft Press 2 Mastering Java 2 John Zukowski Sybex 4
四、 DOM DOM PHP扩展名允许使用W3C DOM API在XML文档上进行操作。在PHP 5出现之前,这是PHP能存取XML文档的唯一方法。如果你在JavaScript中使用了DOM,那么会认识到这些对象模型几乎是一样的。
由于DOM方法在遍历和操作XML文档时比较罗嗦,所以任何DOM兼容的代码都有明显的优点-与任何其它实现相同的W3C兼容的对象模型的API兼容。
在下面的实例代码中,我们使用DOM来显示关于每本书的信息。首先,我们遍历一下列表目录,把它们的Id和相应的名字装载到一个索引数组中。然后,我们显示每本书的一个简短描述:
PHP:
复制代码 代码如下:
/*这里我们必须指定XML版本:也即是1.0 */ $xml = new DomDocument('1.0'); $xml->load('xml/library.xml'); /*首先,创建一个目录列表*/ $categories = array(); $XMLCategories = $xml->getElementsByTagName('categories')->item(0); foreach($XMLCategories->getElementsByTagName('category') as $categoryNode) { /*注意我们是如何得到属性的*/ $cid = $categoryNode->getAttribute('cid'); $categories[$cid] = $categoryNode->firstChild->nodeValue; } ?>
XML Library php foreach($xml->getElementsBytagName('book') as $book):
/*查找标题*/
$title = $book->getElementsByTagName('title')->item(0)->firstChild->nodeValue;
/*查找作者-为了简化起见,我们假设仅仅有一个作者*/
$author = $book->getElementsByTagName('author')->item(0)->firstChild->nodeValue;
/* 列表目录*/
$bookCategories = $book->getElementsByTagName('category');
$catList = '';
foreach($bookCategories as $category) {
$catList .= $categories[$category->firstChild->nodeValue] . ', ';
}
$catList = substr($catList, 0, -2); ?>
php endforeach; ?>
[html]
繰り返しますが、XML の変更はさらに面倒です。たとえば、ディレクトリを追加するコードは次のとおりです。
PHP:
[code]
function addCategory(DOMDocument $xml, $catID, $catName) {
$catName = $xml->gt ;createTextNode($catName); //テキストを保存するノードを作成します
$category = $xml->createElement('category') //カタログ要素を作成します
$category-> ;appendChild( $catName); // カタログ要素にテキストを追加します
$category->setAttribute('cid', $catID) // カタログの ID を設定します
$XMLCategories = $xml- >getElementsByTagName( 'categories')->item(0);
$XMLCategories->appendChild($category); // 新しいディレクトリを追加します
}
5. XML の保存 save() メソッドと saveXML() メソッドのいずれかを使用して、DOM 記述を XML 文字列記述に変換し直すことができます。 save() メソッドは XML を指定された名前でファイルに保存し、saveXML() メソッドはドキュメントの一部または全体から文字列を返します。
$xml->save('xml/library.xml');
//すべてのファイルを保存します
$categories=$xml->saveXML($XMLCategories); // カテゴリを含む文字列を返します
DOM 互換コードを別の言語に移植することがいかに簡単かを示すために、上記と同じ関数を JavaScript で実装するコードを次に示します。
Javascript:
コードをコピー コードは次のとおりです:
function doXML(){ /* まず、カテゴリリスト */ var category = Array(); var XMLCategories = xml.getElementsByTagName('categories')[0] var theCatalog = XMLCategories.getElementsByTagName('category'); for ( var i = 0; i < theCategories.length; i ) { /* 属性の取得方法に注意してください*/ var cid = theCategories[i].getAttribute('cid'); > カテゴリ[cid] = theCategories[i].firstChild.nodeValue; } var theBooks = xml.getElementsByTagName('book'); for(var i = 0; i var book = theBooks[i]; /* タイトルを検索*/ var title = book.getElementsByTagName('title')[0].firstChild.nodeValue; /* 著者を検索します - 簡単にするために、著者は 1 人だけであると仮定します */ var author = book.getElementsByTagName('author')[0].firstChild.nodeValue; /* カテゴリをリストします */ var bookCatalog = book.getElementsByTagName('category'); var catList = ''; for(var j = 0; j < bookCategories.length; j ) { catList = カテゴリ[bookCategories[ j].firstChild.nodeValue] ', '; } catList.substring(0, catList.length -2); document.open(); write(" " タイトル " "); document.write("著者: : " 著者 "
"); Document.write("カテゴリ: : " catList "
"); } document.close() ; } 6. シンプル XML シンプル XML は非常にシンプルです。これにより、オブジェクトおよび配列のアクセス メソッドを使用して、XML ドキュメントとその要素および属性にアクセスできるようになります。操作は簡単です:
· 要素 - これらは SimpleXMLElement オブジェクトの個別のプロパティとして記述されます。複数の要素がドキュメントまたは要素の子として存在する場合、配列インデックス フラグを使用して各要素にアクセスできます。
$xml->books;//要素「books」を返します $xml->books->book[0];//books 要素の最初の本を返します
・属性 - 要素の属性は、連想配列のフラグを通じてアクセスおよび設定されます。このとき、各インデックスは属性名に対応します。
$category['cid']; // cid 属性の値を返します
· 要素データ - 要素内に含まれるテキスト データを取得するには、(string を使用する必要があります) ) 明示的に文字列に変換するか、print または echo を使用して出力します。要素に複数のテキスト ノードが含まれる場合、それらは見つかった順に連結されます。
echo ($xml->books->book[0]->title);//最初の本のタイトルを表示
以下は単純な XML を元に変換したものです実例。 XML ファイルをロードするには、simplexml_load_file() 関数を使用します。この関数は、XML ファイルを解析して SimpleXMLElement オブジェクトにロードします。
PHP:
コードをコピー
コードは次のとおりです:
$xml = simplexml_load_file('xml/library.xml'); /* 把一个列表的目录装载到一个数组中*/ $categories = array(); foreach($xml->categories->category as $category) { $categories[(string) $category['cid']] = (string) $category; } ?>
XML Library books->book as $book):
/* 列举目录*/
$catList = '';
foreach($book->category as $category) {
$catList .= $categories[((string) $category)] . ', ';
}
$catList = substr($catList, 0, -2); ?>
title) ?> Author: : author) ?>
Categories: : php echo($catList) ?>
php endforeach;
7.テキストデータや属性値は単純なXMLを使用して設定できますが、これらのオブジェクトを新規作成することはできません。ただし、SimpleXM は、DomElement オブジェクトと DomElement オブジェクトの間で変換する方法を提供します。これを行うために、addCategory() 関数を変更して、simplexml_import_dom() 関数を使用してカタログを追加し、ドキュメントを単純な XML 形式に変換する方法を示しました。
PHP: コードをコピー
コードは次のとおりです。
function addCategory(SimpleXMLElement &$sXML, $catID, $catName) { $xml = new DOMDocument; $ xml->loadXML($sXML->asXML());
$catName = $xml->createTextNode($catName); // テキストを格納するノードを作成します。 >$category = $ xml->createElement('category'); // カタログ要素を作成します
$category->appendChild($catName); // カタログ要素にテキストを追加します $category- >setAttribute(' cid', $catID); // ディレクトリ ID を設定します $XMLCategories = $xml->getElementsByTagName('categories')->item(0); appendChild($category) ; // 新しいディレクトリを追加します $sXML = simplexml_import_dom($xml); return $sXML; 同様に、 SimpleXMLElement オブジェクトの関数を使用して、XML 文字列を取得し、ファイルに保存し直すことができます。 8. xPath Xpath が「XML ケーキの上のチェリー」であることは疑いの余地がありません。 XPath を使用すると、SQL のようなクエリを使用して、XML ドキュメント内の特定の情報を検索できます。 DOM と SimpleXML にはどちらも XPath のサポートが組み込まれており、SQL と同様に、XML ドキュメントから必要なコンテンツを抽出するために使用できます。
プログラム コード
· //category - ドキュメント内に表示されるすべてのカテゴリを検索します。
· /library/books - library の子として表示されるすべての書籍を検索します · /library/categories/category[@cid] - library/categories の子として表示されるすべての書籍を検索しますand have 属性は cid のカテゴリです。
· /library/categories/category[@att='2'] - library/categories の子として表示され、値 2 の属性 cid を持つすべてのカテゴリを検索します。
· /library/books/book[title='Apache 2'] - /library/books の子であり、title 要素の値が Apache 2 である book をすべて検索します。
実際、これは xPath の氷山の一角にすぎません。 xPath を使用すると、ドキュメントからほぼすべての情報を抽出するための多数の複雑なクエリを作成できます。 xPath を使用することがいかに簡単で楽しいかを示すために、サンプル コードを再度変更しました。
PHP:
コードをコピー
コードは次のとおりです:
$xml = simplexml_load_file('xml/library.xml');
/title> head> xpath("/library/books/book")): /*list Directory*/
$catList = ''; foreach($book->category as $category) { /*この ID のディレクトリを取得*/ $category = $xml- >xpath("/library/categories/category[@cid='$category']"); $catList .= (文字列) ', ' } $catList = substr($catList, 0, -2);
title) ?> h2> :author) ?>
p>
カテゴリ: :
9. DOM と XPath
DOM で XPath クエリを計算するには、DOMXPath オブジェクトを作成する必要があります。次の Evaluate() 関数は DOMElement の配列を返します。
コードをコピー
コードは次のとおりです。
$xPath = new DOMXPath($xml); ->evaluate("/library/books/book[title='Apache 2']");
10. 結論
PHP が提供するツールを使用して XML を操作する方法を学びました。この時点で、「準備が整い」、XML アプリケーションを詳しく調べる準備が整いました。次の記事では、AJAX と、それが Google などのサイト開発でどのように使用されるかについて説明します。