您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何理解J2ME的Web服務API,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
你對J2ME的Web服務API是否了解,這里和大家分享一下,Java2平臺袖珍版(J2ME)平臺中的Web服務是由Java規范請求172(JSR172)定義的,它與標準Web服務遵循同樣的規范、結構以及調用模型。
J2ME的Web服務API講解
用于Java2平臺袖珍版(Java2Platform,MicroEdition,J2ME)的Web服務API(WSA)是由JavaCommunityProcess為Java規范請求172(JSR172)而定義的,這些API是兩個相互獨立的可選包,用于遠程服務調用和XML解析。他們是針對基于連接設備配置(ConnectedDeviceConfiguration,CDC)和有限連接設備配置(ConnectedLimitedDeviceConfiguration,CLDC1.0和CLDC1.1)的框架的。為什么用戶應該關注這些呢?因為JSR172在設備層為遠程服務調用和XML解析提供了支持,也就意味著開發人員不用將這項功能嵌入到每一個應用程序中。本文介紹了遠程服務調用可選包API。
J2ME中的Web服務
Java2平臺袖珍版(J2ME)平臺中的Web服務是由Java規范請求172(JSR172)定義的,它與標準Web服務遵循同樣的規范、結構以及調用模型。我們來回顧一下清單。
與標準Web服務的比較
JSR172Web服務API(WSA)遵循下面這些核心Web服務規范:
簡單對象訪問協議(SOAP)1.1,定義傳輸和數據編碼。
Web服務定義語言(WSDL)1.1,定義如何描述遠程服務。
XML1.0,定義XML標記語言。
XMLSchema,毫無疑問,定義XML模式。
注意JSR172不支持統一描述、發現和集成(UDDI)2.0規范,該規范定義了如何發現遠程服務。
由于有相當多的與Web服務相關并且涵蓋了不同技術的規范出臺,而且越來越多,Web服務互操作組織(WS-I)定義了WS-I基本概要1.0(WS-IBasicProfile,Version1.0)來定義Web服務規范的最小集,和一致性規則一樣,所有的基礎Web服務提供者和消費者都必須遵守該概要。JSR172規范也遵守WS-I基本概要。
與標準Web服務具有相同的體系結構:
JSR172WSA從客戶端訪問Web服務,從服務-消費者的角度來看,WSA提供遠程服務調用API(JAX-RPC)以及運行時環境,從而允許J2ME應用程序在Web上消費服務,而不是作為服務生產者(端點)來運行。除了這一點差別之外,JSR172WSA體系結構的其它部分與Web服務的標準體系結構/組織一致,如下圖所示:
該高級體系結構組織如下:
客戶端,Web服務消費者:它是J2ME應用程序,例如MIDP或個人版基于框架的應用程序,JSR172存根和支持類,以及JSR172運行時。
網絡:指的是無線和有線網絡以及通信協議,無線和有線網絡是Internet的一部分。注意JSR172本身沒有規定在設備上使用XML編碼方法,而允許執行程序(只要它們對消費者和生產者是透明的)使用更有效的編碼方法,例如在設備和無線網關之間使用二進制協議。
服務器,Web服務生產者:它是一個Web服務器,通常位于防火墻和/或代理網關的后面。該服務器可以訪問后臺資源。
調用模型和數據流與標準Web服務相同:
J2ME應用程序通過JSR172存根和運行時調用遠程服務,通常要通過HTTP和SOAP來進行傳輸。存根和運行時將與遠程服務調用相關的復雜部分都隱藏起來了,包括輸入值和返回值如何編碼并解碼,以及與服務器進行網絡通信的管理。方法調用遵循同步請求-應答模型,如下圖所示:
圖2-JSR172調用模型
*由于調用是按模塊進行的,所以您應該把這些調用分派到不同的執行線程中。
消費Web服務
要消費Web服務,您必須首先創建服務調用存根。讓這些存根來執行任務,例如對輸入值和返回值進行編碼和解碼、與JSR172運行時交互來調用遠程服務端點。存根通過運行時的服務提供者接口(SPI)與運行時進行交互,這樣通過概述運行時執行的詳細情況,使存根在不同廠商之間的執行更便捷。
存根通常是用工具生成的,該工具讀取一個WSDLXML文檔,文檔描述了將要使用到的Web服務。同樣的,WSDL文檔通常也是通過工具生成的,該工具讀取接口定義,例如Java接口產生了WSDL文檔。
從我們移動開發的角度來看,需要消費的WSDL文檔通常已經存在,您需要做的僅僅是生成JSR172WSA存根。要生成這些存根,您應該使用例如J2MEWirelessToolkit2.1存根生成器這樣的工具,如下圖所示:
圖3-生成JSR172WSA存根
該生成器生成存根Java文件,以及相關的支持類。如下一部分所描述的,它還考慮到了WSDL到Java的數據類型映射。
一旦生成了JSR172JAX-RPC存根和支持文件,您的應用程序就已經被編譯并部署到啟用了JSR172的設備上了,消費Web服務是很簡單的而且幾乎是透明的。您很快就會看到,調用遠程方法幾乎和調用本地方法一樣簡單。
JSR172JAX-RPC子集API
JSR172遠程方法調用API是以基于XML的RPC的J2SEJavaAPI(JAX-RPC1.1)的子集為基礎的。它同樣遵守WS-I基本概要。下面來詳細研究一下JSR172JAX-RPC子集API:
它支持:
SOAP1.1。
任何可以傳送SOAP消息的傳輸,例如HTTP1.1,都有一個定義好的用于SOAP1.1的協議綁定。
SOAP消息的文字表示代表一個RPC調用或應答。
下面(是)數據類型和相應的Java映射:
xsd:boolean到boolean或Boolean。
xsd:byte到byte或Byte。
xsd:short到short或Short。
xsd:int到int或Integer。
xsd:long到long或Long。
xsd:float到float,或Float。對基于CLDC1.0的平臺,該數據類型映射到String。
xsd:double到double,或Double。對基于CLDC1.0的平臺,該數據類型映射到String。
xsd:string到String。
xsd:base64Binary到byte[]。
xsd:hexBinary到byte[]。
xsd:complexType到基本類型和類類型序列。
xsd:QName到javax.xml.namespace.QName。
以XML數組模式為基礎的基本類型和復雜類型(結構中包含基本類型或復雜類型)數組。
它不支持:
帶附件的SOAP消息。
SOAP消息處理器。
SOAP消息的編碼表示。
服務端點(不是Web服務生產者)。
服務發現支持(UDDI)。
設備端沒有規定XML編碼方法。這樣做是通過允許執行程序使用更有效的數據編碼方法來幫助減少網絡傳輸,例如在設備和無線網關間使用二進制協議(只要這樣編碼對消費者和生產者是透明的)。
JSR172遠程調用API包括下面這些包:
javax.microedition.xml.rpc
javax.xml.namespace
javax.xml.rpc
java.rmi(包括確保JAX-RPC相關型)
注意這些API(有一些異常API,例如RemoteException)不是直接由應用程序調用,相反,應用程序調用生成的存根。上面的API主要是供存根使用的。有關詳細信息請參閱JSR172規范和/或Java文檔。
使用JSR172JAX-RPC調用遠程服務
一旦生成、編譯并部署了JSR172JAX-RPC存根和支持文件,消費遠程服務就很容易了。事實上,除了導入RemoteException,完成最少量的JAX-RPC細節初始化工作,您的應用程序不光是看上去,而且運行起來也和非Web服務消費者應用程序一樣。由于有JSR172存根和運行時,實現這種簡單的應用程序是可能的,正如前面提到的,JSR172存根和運行時把與遠程調用相關的大部分細節都隱藏了。
要調用遠程服務,您首先需要實例化存根,完成最少的存根初始化工作,然后就是如何編寫調用存根方法。下面的代碼片斷顯示了如何使用JSR172JAX-RPC調用遠程服務。
關于如何理解J2ME的Web服務API就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。