用XSL翻譯網絡服務應用程式

黄舟
發布: 2017-03-03 17:15:59
原創
1728 人瀏覽過

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)!


#
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板