《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 其他 > 業(yè)界動(dòng)態(tài) > J2EE環(huán)境下WebServices框架的實(shí)現(xiàn)

J2EE環(huán)境下WebServices框架的實(shí)現(xiàn)

2009-01-08
作者:謝飛

1.框架背景?

??? J2EE是跨平臺(tái)的,而WebServices的核心XML也是跨平臺(tái)的,因此兩者結(jié)合更能發(fā)揮它們各自的功效。關(guān)于WebServices的概念、作用、實(shí)現(xiàn)等,本文不作詳細(xì)的介紹,背景部分主要介紹一下在J2EE環(huán)境下實(shí)現(xiàn)WebServices框架所需要的環(huán)境。?

(1)Tomcat?

??? 本框架使用的Web服務(wù)器為Tomcat4.x,具體下載地址:http://jakarta.apache.org。遵循J2EE1.3規(guī)范,包括JSP1.2和Servlet2.3。由于Axis是以Web應(yīng)用的形式發(fā)布的,所以需要一個(gè)Web服務(wù)器。?

(2)Axis?

??? Axis框架來自 Apache 開放源代碼組織,它是基于JAVA語言的最新的 SOAP 規(guī)范(SOAP 1.2)和 SOAP with Attachments 規(guī)范(來自 Apache Group )的開放源代碼實(shí)現(xiàn)。Axis的最新版本是1.1,可以從http://ws.apache.org/axis/index.html下載。?

(3)JAXB?

??? JAXB是一個(gè)數(shù)據(jù)綁定工具,相關(guān)資料和下載可以到j(luò)ava.sun.com/webservices/,JAXB主要可以實(shí)現(xiàn):把 XML 數(shù)據(jù)轉(zhuǎn)化成 Java 類(或者多個(gè)類);把 Java 數(shù)據(jù)轉(zhuǎn)化成 XML 文檔。使用 JAXB 時(shí)需要一個(gè) XML Schema 以生成類和數(shù)據(jù)結(jié)構(gòu)。?

2.框架目標(biāo)?

??? 本框架主要目的是使開發(fā)WebServices應(yīng)用變得簡(jiǎn)單、高效,使WebServices應(yīng)用易于擴(kuò)展和維護(hù)。具體來講,包括以下幾方面:?

(1)提供給用戶的WebServices接口簡(jiǎn)單,提供單點(diǎn)入口,這樣用戶不需要記住很多繁瑣的方法。?

(2)WebServices的服務(wù)端和客戶端的數(shù)據(jù)全部通過XML交互,目前很多行業(yè)都形成了XML規(guī)范,例如旅游電子商務(wù),如果嚴(yán)格按照XML規(guī)范,可以達(dá)到各個(gè)系統(tǒng)之間的整合。?

(3)WebService的調(diào)用通過XML事件實(shí)現(xiàn)。一個(gè)XML文檔就是一個(gè)WebServices事件,激發(fā)一個(gè)系統(tǒng)后臺(tái)的調(diào)用。?

(4)維護(hù)WebServices方便,例如方便的添加、修改、刪除一個(gè)WebServices提供的功能。?

(5)方便測(cè)試WebServices提供的功能,可以在脫離WebServices的環(huán)境下測(cè)試。?

3.框架實(shí)現(xiàn)原理?

??? 一個(gè)WebServices訪問大致流程為:首先互聯(lián)網(wǎng)用戶向WebServices客戶端服務(wù)器發(fā)出某請(qǐng)求,然后客戶端服務(wù)器發(fā)送一個(gè)XML事件到WebServices服務(wù)器,WebServices服務(wù)器解析XML事件,調(diào)用相應(yīng)的后臺(tái)業(yè)務(wù)邏輯,并將結(jié)果以XML的形式返回給客戶端。本框架是用于基于Servlet的WebServices,主要任務(wù)就是解析XML事件,調(diào)用相應(yīng)的業(yè)務(wù)邏輯,然后將結(jié)果以XML的格式反饋給客戶方,其中還包括了錯(cuò)誤處理。具體的流程圖如下:

①??WebServices客戶端首先根據(jù)用戶的請(qǐng)求封裝XML,然后發(fā)送到WebServices服務(wù)器端。其中的XML文檔必須符合WebServices服務(wù)器端定義的Schema,一個(gè)不同的XML文檔對(duì)應(yīng)一個(gè)不同的請(qǐng)求。其中XML最好能遵循行業(yè)規(guī)范,例如旅游電子商務(wù)XML規(guī)范,有利于和其他系統(tǒng)交互。

②??WebServices服務(wù)器端的Servlet服務(wù)程序?yàn)閃ebServicesEngine,提供唯一的訪問入口doService(),所有的客戶端都是訪問WebServicesEngine的doService()方法。當(dāng)服務(wù)器端接收到一個(gè)XML事件請(qǐng)求,首先解析這個(gè)XML(可以通過JAXB或者castor),然后調(diào)用相應(yīng)的系統(tǒng)Action,Action的主要任務(wù)為獲取XML中的數(shù)據(jù)。

③??Action將XML數(shù)據(jù)封裝成系統(tǒng)的Model,然后調(diào)用WebServices的業(yè)務(wù)代理層。

④??WebServices的業(yè)務(wù)代理層調(diào)用后臺(tái)應(yīng)用服務(wù)器的EJB。

⑤??后臺(tái)執(zhí)行完后,將結(jié)果返回給WebServices的業(yè)務(wù)代理層。

⑥??WebServices的業(yè)務(wù)代理層將結(jié)果返回給Action。

⑦??Action再將具體的結(jié)果封裝成XML返回給WebServicesEngine。

⑧??最后WebServicesEngine將XML返回到WebServices客戶端。

??? 具體的XML請(qǐng)求和Action的對(duì)應(yīng)關(guān)系在一個(gè)request.xml中定義,對(duì)于客戶端來說,一個(gè)XML文檔就是一個(gè)功能請(qǐng)求,對(duì)于WebServices開發(fā)者來說,一個(gè)Action就是一個(gè)提供給外界的功能,兩者的關(guān)系由request.xml決定。其中這個(gè)request.xml具體由WebServicesEngine解析。

4.框架具體實(shí)現(xiàn)?

(1)? 將XML Schema轉(zhuǎn)化為java程序。

??? 首先需要安裝jaxb,然后執(zhí)行命令:xjc.bat -p com.webservice.jaxbmodel WebService.xsd -d src,即可在src目錄下生成java程序,然后編譯。

(2)? 解析XML請(qǐng)求,然后選擇相應(yīng)的Action執(zhí)行請(qǐng)求

??? 首先定義request.xml文件,格式如下:

?????? com.webservice.jaxbmodel.CreateOrderRequest

??????? com.webservice.action.CreateOrderAction

其中CreateOrderRequest是由JAXB從XML Schema生成出來的類,當(dāng)XML請(qǐng)求到達(dá),首先通過JAXB把XML文檔unmarshal成java對(duì)象,例如CreateOrderRequest,然后通過反射機(jī)制查找到類CreateOrderAction,然后實(shí)例化,然后執(zhí)行Action的execute方法調(diào)用后臺(tái)具體的業(yè)務(wù)邏輯。為了提高效率,可以把Action設(shè)置成單例,類似于Struts(jakarta.apache.org)的Action,其中Action只做流程控制。

(3)? 錯(cuò)誤處理

??? 考慮到WeServices客戶端的多樣性,例如.NET、VB、Delphi等,有些語言并沒提供類似于java的例外(Exception)處理,因此本框架并未使用例外機(jī)制,而用一個(gè)專用的XML文檔表示錯(cuò)誤信息,其中有一個(gè)ErrorCode來表示具體的錯(cuò)誤信息。格式如下:

??????? 500

??? 如果返回給客戶端的XML為錯(cuò)誤文檔,則可以根據(jù)ErrorCode查詢到具體的錯(cuò)誤信息。具體ErrorCode的錯(cuò)誤信息由WebServices提供者提供。

(4)? 返回XML結(jié)果

??? WebServices客戶端接收到XML文檔后,需要首先解析此XML是否為錯(cuò)誤XML文檔,如果是,則將錯(cuò)誤的信息顯示給用戶,否則,解析XML文檔,將XML數(shù)據(jù)反饋給最終用戶。

5.框架展望和小結(jié)?

??? 本框架的主要目的就是加快用戶開發(fā)WebServices的速度,如果對(duì)已有系統(tǒng)開發(fā)WebServices,則只需要首先制定一些XML規(guī)范(Schema),然后編寫相應(yīng)的Action,Action去調(diào)用現(xiàn)有的業(yè)務(wù)邏輯,而不用去關(guān)心WebServices的具體細(xì)節(jié),如此一來,可以大大的提高效率。

??? 當(dāng)然,此框架還有很多未考慮的因素,例如WebServices安全等,因此有待進(jìn)一步改善。

參考資料

1.http://java.sun.com/webservices/

2.http://ws.apache.org/axis/index.html

3.IBM developerWorks中文網(wǎng)站

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請(qǐng)及時(shí)通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。