使用PHP和XSL stylesheets轉換XML文檔

來源:互聯網
上載者:User
xml|轉換 PHP是不少在Web開發領域奮戰的勇士們所選用的武器,因為它是一種很直觀的程式設計語言,有強大的函數,良好的跨平台相容性,還有它是免費的。從網上的小商店到大型企業的網站都能看到PHP的影子。


PHP有一點特性經常被人們忽視,那就是和XSL stylesheets合作對XML進行解析的能力。下面就讓我們來看看怎樣在PHP中設定一個XSL解析器以及你該如何使用這一功能。


例子
列表A是一個簡單的訂單文檔,我們會將這個文檔輸入XSL解析器。同時,列表B中的XSL stylesheet也會被輸入XSL解析器。

Listing A: order.xml

<?xml version="1.0" ?>
<Order>
<Account>9900234</Account>
<Item id="1">
<SKU>1234</SKU>
<PricePer>5.95</PricePer>
<Quantity>100</Quantity>
<Subtotal>595.00</Subtotal>
<Description>Super Widget Clamp</Description>
</Item>
<Item id="2">
<SKU>6234</SKU>
<PricePer>22.00</PricePer>
<Quantity>10</Quantity>
<Subtotal>220.00</Subtotal>
<Description>Mighty Foobar Flange</Description>
</Item>
<Item id="3">
<SKU>9982</SKU>
<PricePer>2.50</PricePer>
<Quantity>1000</Quantity>
<Subtotal>2500.00</Subtotal>
<Description>Deluxe Doohickie</Description>
</Item>
<Item id="4">
<SKU>3256</SKU>
<PricePer>389.00</PricePer>
<Quantity>1</Quantity>
<Subtotal>389.00</Subtotal>
<Description>Muckalucket Bucket</Description>
</Item>
<NumberItems>1111</NumberItems>
<Total>3704.00</Total>
<OrderDate>07/07/2002</OrderDate>
<OrderNumber>8876</OrderNumber>
</Order>
Listing B: order.xsl

<?xml version="1.0" ?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:param name="column" select="'SKU'"/>
<xsl:param name="order" select="'ascending'"/>
<xsl:template match="/">
<html>
<body>
<xsl:apply-templates select="Order">
<xsl:with-param name="sortcolumn" select="$column" />
<xsl:with-param name="sortorder" select="$order" />
</xsl:apply-templates>
</body>
</html>
</xsl:template>

<xsl:template match="Order">
<xsl:param name="sortcolumn" />
<xsl:param name="sortorder" />
<table border="1">
<tr>
<th>Account</th>
<th>SKU</th>
<th>Description</th>
<th>Price</th>
<th>Quantity</th>
<th>Subtotal</th>
</tr>
<xsl:apply-templates select="Item">
<xsl:sort select="*[name()=$sortcolumn]" order="{$sortorder}" />
</xsl:apply-templates>
</table>
</xsl:template>

<xsl:template match="Item">
<tr>
<td><xsl:value-of select="../Account" /></td>
<td><xsl:value-of select="SKU" /></td>
<td><xsl:value-of select="Description" /></td>
<td><xsl:value-of select="PricePer" /></td>
<td><xsl:value-of select="Quantity" /></td>
<td><xsl:value-of select="Subtotal" /></td>
</tr>
</xsl:template>
</xsl:stylesheet>
概述
在這個例子中我們主要用到PHP中的三個XSL函數。首先我們要建立一個XSL引擎的執行個體,然後把所有要輸入的文檔輸入這個XSL引擎進行處理,並得到返回結果,最後,當我們再也不需要這個XSL引擎時就關閉它。


建立、處理、關閉
我們將要在記憶體中建立一個XSL進程。為了方便在其他XSL函數中使用這個XSL進程,PHP會給我們提供這個XSL進程的控制代碼,而不是一個對象。建立這個XSL引擎的命令是xslt_create。函數返回一個控制代碼,如下所示:

$handle = xslt_create();

為了真正的解析XML文檔並使XSLT能夠進行處理,你必須使用PHP中的xslt_process函數。這個函數需要擷取幾個不同的參數。

在這裡我們使用一個很基本的方法,為xslt_process提供三個參數。第一個參數是我們較早前建立的那個XSL引擎的控制代碼。第二個參數是輸入的XML文檔的檔案名稱。第三個參數是輸入的XSL檔案的檔案名稱。這個函數會返回處理結果。下面是例子:

$return = xslt_process($handle, $xmlfile, $xslfile);

最後我們要用到的函數是xslt_free。這個函數用來殺掉記憶體中的XSL引擎執行個體並釋放出記憶體空間。它只需要一個參數,就是記憶體中這個XSL執行個體的控制代碼。下面是個例子:

xslt_free($handle);

綜合實現

下面讓我們結合上面的各個代碼片斷實現PHP通過XSL stylesheets來處理XML文檔的方法。我們使用列表A作為我們的輸入XML文檔,列表B作為我們XSL輸入。列表C是這個例子的完整PHP代碼:

Listing C: order.php

<?php
$xmlfile = "order.xml";
$xslfile = "order.xsl";
$args = array("column"=>"Quantity", "order"=>"descending");
$engine = xslt_create();
$output = xslt_process($engine, $xmlfile, $xslfile, NULL, NULL, $args);
print $output;
xslt_free($engine);
?>

這裡需要注意一點,我們在代碼中做了一點變動。在XSL stylesheet中,通過指定一些參數,我們可以改變一些地區,比如地址。這時我們要指定訂單上的項目應該按數量遞減方式排列。我們使用PHP的數組來儲存名字對應我們的參數,然後通過xslt_process函數將名字傳遞給XSL引擎。


本文作者Brian Schaffner是富士通諮詢公司的副主任。他為富士通的技術諮詢公司提供架構、設計和開發支援。




相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。