用XSL翻譯網絡服務應用程式
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)!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

一、日誌輸出到檔案使用模組:logging可以產生自訂等級日誌,可以輸出日誌到指定路徑日誌等級:debug(偵錯日誌)=5){clearTimeout(time)//如果連續10次取得的都是空日誌清除定時任務}return}if(data.log_type==2){//如果取得到新日誌for(i=0;i

Caddy簡介Caddy是一款功能強大,擴展性高的Web伺服器,目前在Github上已有38K+Star。 Caddy採用Go語言編寫,可用於靜態資源託管和反向代理。 Caddy具有以下主要特性:比較Nginx複雜的配置,其獨創的Caddyfile配置非常簡單;可以透過其提供的AdminAPI實現動態修改配置;預設支援自動化HTTPS配置,能自動申請HTTPS憑證並進行配置;能夠擴展到數以萬計的站點;可以在任意地方執行,沒有額外的依賴;採用Go語言編寫,內存安全更有保證。安裝首先我們直接在CentO

防擋臉彈幕,即大量彈幕飄過,但不會遮擋視訊畫面中的人物,看起來像是從人物背後飄過去的。機器學習已經火了好幾年了,但很多人都不知道瀏覽器中也能運行這些能力;本文介紹在視頻彈幕方面的實踐優化過程,文末列舉了一些本方案可適用的場景,期望能開啟一些腦洞。 mediapipeDemo(https://google.github.io/mediapipe/)展示主流防擋臉彈幕實現原理點播up上傳視訊伺服器後台計算提取視訊畫面中的人像區域,轉換成svg儲存用戶端播放視訊的同時,從伺服器下載svg與彈幕合成,人像

JavaAPI開發中使用Jetty7進行Web伺服器處理隨著互聯網的發展,Web伺服器已經成為了應用程式開發的核心部分,同時也是許多企業所關注的焦點。為了滿足日益增長的業務需求,許多開發人員選擇使用Jetty進行Web伺服器開發,其靈活性和可擴展性受到了廣泛的認可。本文將介紹如何在JavaAPI開發中使用Jetty7進行We

首先你會有個疑惑,frp是什麼呢?簡單的說frp就是內網穿透工具,配置客戶端以後,可以透過伺服器來存取內部網路。現在我的伺服器,已經用nginx做站了,80端口只有一個,那如果frp的服務端也想使用80端口,那該怎麼辦呢?經過查詢,這個是可以實現的,就是利用nginx的反向代理來實現。補充一下:frps就是伺服器端(server),frpc就是客戶端(client)。第一步:修改伺服器中nginx.conf設定檔在nginx.conf中http{}裡加入以下參數,server{listen80

表單驗證是Web應用程式開發中非常重要的環節,它能夠在提交表單資料之前對資料進行有效性檢查,避免應用程式出現安全漏洞和資料錯誤。使用Golang可以輕鬆實現網頁應用程式的表單驗證,本文將介紹如何使用Golang來實作網頁應用程式的表單驗證。一、表單驗證的基本要素在介紹如何實作表單驗證之前,我們需要知道表單驗證的基本要素是什麼。表單元素:表單元素是指

Web標準是一組由W3C和其他相關組織制定的規範和指南,它包括HTML、CSS、JavaScript、DOM、Web可訪問性和性能優化等方面的標準化,透過遵循這些標準,可以提高頁面的兼容性、可訪問性、可維護性和效能。 Web標準的目標是使Web內容能夠在不同的平台、瀏覽器和裝置上一致地展示和交互,提供更好的使用者體驗和開發效率。

nginx不只可以隱藏版本信息,還支援自訂web伺服器資訊先看看最終的隱藏結果吧具體怎麼實現呢,其實也很簡單,請往下看1官網下載最新穩定版wgethttp://nginx.org/ download/nginx-1.14.1.tar.gz2解壓tar-xfnginx-1.14.1.tar.gzcdnginx-1.14.13修改c文件(1)vimsrc/http/ngx_http_header_filter_module.c #修改49行staticu_charngx_http_
