Web服務應用程式存在的一個常見問題是,真正的後端軟體不支援xml(或至少不支援你Web服務所使用的標準化的XML)。要解決這個問題,許多架構都實作了一個翻譯階段,用來解釋收到的XML,並將它轉換成後端系統能夠辨識的更適當的格式。雖然將XML翻譯成不同的格式有很多種方式法,但是可擴展樣式表語言(eXtensibleStylesheet Language,XSL)提供了一個強健的、標準的和對XML友好的解決方案。
一些常見的問題
在XML訊息和將要處理它的應用程式之間,存在著許多可能需要翻譯的地方。但是,這也存在著許多常見的問題,包括:
查詢(Lookup)
映射(Mapping)
聚合(Aggregation)
分割(Splitting)
公式(Formulas )
重新排序(Reordering)
查詢處理會接受收到的值,並為目標系統將它對應到不同的值。例如,你的XML有一個值是309,但是應用程式需要的值是「Uber Widget」。
映射在本質上是將來自一個欄位的值重新指派為另一個值。例如,在XML裡,你可能有一個AccountNumber元素,它需要被重新指派成為一個叫做CustomerAccountNumber的新元素。
聚合處理是將兩個或更多來自XML的項目組合成一個用於後端系統的單一項目。一個常見的例子是將姓和名字段組合成單一的姓名(欄位)。分割是聚合的逆向操作,它是將XML的一個值分成兩個或更多分開的元件。
公式處理一般涉及對一個或更多XML值的計算,以獲得一個用於新應用程式的值。一個例子是利用XML裡子定單來計算定單的總量。
最後,重排序是更改XML裡項目的序列或結構的處理,這樣它們就能夠符合目標系統所期望的序列或結構。
映射舉例
現在讓我們用一個例子來更仔細地看看這個過程。我們假設收到的XML就像Listing 1裡面的一樣:
Listing 1: webserviceorder.xml
<?xml version="1.0" ?> <Order> <OrderNumber>8100</OrderNumber> <AccountNumber>99213</AccountNumber> <Item> <SKU>2388</SKU> <Description>Uber Widget</Description> <Quantity>15</Quantity> <PRicePer>10.95</PricePer> </Item> <Item> <SKU>6273</SKU> <Description>Flangeoid</Description> <Quantity>10</Quantity> <PricePer>52.00</PricePer> </Item> </Order>
現在,我們的訂單系統需要一個稍微不同的格式。我們所需要做的是將從Web服務收到的訂單轉換成為Listing 2裡的這種格式。
Listing 2: applicationorder.xml
<?xml version="1.0" encoding="UTF-8" ?> <NeWorder> <CustomerAccountNumber>99213</CustomerAccountNumber> <CustomerOrderNumber>8100</CustomerOrderNumber> <OrderItems> <OrderItem> <SKU>2388</SKU> <CustomerPrice>10.95</CustomerPrice> <Quantity>15</Quantity> <Subtotal>164.25</Subtotal> </OrderItem> <OrderItem> <SKU>6273</SKU> <CustomerPrice>52.00</CustomerPrice> <Quantity>10</Quantity> <Subtotal>520</Subtotal> </OrderItem> </OrderItems> </NewOrder>
翻譯
由於這是一個簡化的例子,所以我們在轉換格式的時候需要對XSL模板所做的只有不多的事情。我們要注意的第一件事是:我們必須映射一些元素:
把Order映射成NewOrder
把AccountNumber映射成CustomerAccountNumber
把OrderNumber映射成CustomerOrderNumber
把Item映射成OrderItem
把PricePer映射成CustomerPrice
#然後,我們需要將OrderItem元素重新安排到一個叫做OrderItems的新元素之下。最後,我們加入一個叫做Subtotal的新元素,它會根據(商品)單價和數量進行計算。
映射翻譯是最簡單的,因為你只需要簡單地在範本裡定義新元素,並指明這個新元素擁有來自收到的XML文件裡元素的值。對Items的重排序是透過將Item子模板呼叫放進一個叫做OrderItems的新元素裡實現的。最後,使用一個簡單的XPath表達式來進行計算。 Listing 3顯示了用來將收到的XML轉換成針對應用程式的XML的XSL文件。
Listing 3: translate.xsl
<?xml version="1.0" ?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:template match="/"> <xsl:apply-templates select="Order" /> </xsl:template> <xsl:template match="Order"> <NewOrder> <CustomerAccountNumber><xsl:value-of select="AccountNumber" /></CustomerAccountNumber> <CustomerOrderNumber><xsl:value-of select="OrderNumber" /></CustomerOrderNumber> <OrderItems> <xsl:apply-templates select="Item" /> </OrderItems> </NewOrder> </xsl:template> <xsl:template match="Item"> <OrderItem> <SKU><xsl:value-of select="SKU" /></SKU> <CustomerPrice><xsl:value-of select="PricePer" /></CustomerPrice> <Quantity><xsl:value-of select="Quantity" /></Quantity> <Subtotal><xsl:value-of select="PricePer * Quantity" /></Subtotal> </OrderItem> </xsl:template> </xsl:stylesheet>
以上就是用XSL翻譯Web服務應用程式的內容,更多相關內容請關注PHP中文網(www.php.cn)!