這篇文章主要為大家展示了“WebService的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“WebService的示例分析”這篇文章吧。
成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供黃浦網站建設、黃浦做網站、黃浦網站設計、黃浦網站制作等企業(yè)網站建設、網頁設計與制作、黃浦企業(yè)網站模板建站服務,10余年黃浦做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。
一、序言
大家或多或少都聽過 WebService(Web服務),有一段時間很多計算機期刊、書籍和網站都大肆的提及和宣傳WebService技術,其中不乏很多吹噓和做廣告的成 分。但是不得不承認的是WebService真的是一門新興和有前途的技術,那么WebService到底是什么?何時應該用?
當前的應用程序開發(fā)逐步的呈現(xiàn)了兩種迥然不同的傾向:一種是基于瀏覽器的瘦客戶端應用程序,一種是基于瀏覽器的富客戶端應用程序(RIA),當然后一種技術相對來說更加的時髦一些(如現(xiàn)在很流行的Html5技術),這里主要講前者。
基于瀏覽器的瘦客戶端應用程序并不是 因為瘦客戶能夠提供更好的用戶界面,而是因為它能夠避免花在桌面應用程序發(fā)布上的高成本。發(fā)布桌面應用程序成本很高,一半是因為應用程序安裝和配置的問 題,另一半是因為客戶和服務器之間通信的問題。傳統(tǒng)的Windows富客戶應用程序使用DCOM來與服務器進行通信和調用遠程對象。配置好DCOM使其在 一個大型的網絡中正常工作將是一個極富挑戰(zhàn)性的工作,同時也是許多IT工程師的噩夢。事實上,許多IT工程師寧愿忍受瀏覽器所帶來的功能限制,也不愿在局 域網上去運行一個DCOM。關于客戶端與服務器的通信問題,一個完美的解決方法是使用HTTP協(xié)議來通信。這是因為任何運行Web瀏覽器的機器都在使用 HTTP協(xié)議。同時,當前許多防火墻也配置為只允許HTTP連接。許多商用程序還面臨另一個問題,那就是與其他程序的互操作性。如果所有的應用程序都是使 用COM或.NET語言寫的,并且都運行在Windows平臺上,那就天下太平了。然而,事實上大多數商業(yè)數據仍然在大型主機上以非關系文件(VSAM) 的形式存放,并由COBOL語言編寫的大型機程序訪問。而且,目前還有很多商用程序繼續(xù)在使用C++、Java、Visual Basic和其他各種各樣 的語言編寫?,F(xiàn)在,除了最簡單的程序之外,所有的應用程序都需要與運行在其他異構平臺上的應用程序集成并進行數據交換。這樣的任務通常都是由特殊的方法, 如文件傳輸和分析,消息隊列,還有僅適用于某些情況的的API,如IBM的高級程序到程序交流(APPC)等來完成的。在以前,沒有一個應用程序通信標 準,是獨立于平臺、組建模型和編程語言的。只有通過Web Service,客戶端和服務器才能夠自由的用HTTP進行通信,不論兩個程序的平臺和編程語言是什么。
二、WebService到底是什么
一言以蔽之:WebService是一種跨編程語言和跨操作系統(tǒng)平臺的遠程調用技術。
所謂跨編程語言和跨操作平臺,就是說服務端程序采用java編寫,客戶端程序則可以采用其他編程語言編寫,反之亦然!跨操作系統(tǒng)平臺則是指服務端程序和客戶端程序可以在不同的操作系統(tǒng)上運行。
所謂遠程調用,就是一臺計算機a上 的一個程序可以調用到另外一臺計算機b上的一個對象的方法,譬如,銀聯(lián)提供給商場的pos刷卡系統(tǒng),商場的POS機轉賬調用的轉賬方法的代碼其實是跑在銀 行服務器上。再比如,amazon,天氣預報系統(tǒng),淘寶網,校內網,百度等把自己的系統(tǒng)服務以webservice服務的形式暴露出來,讓第三方網站和程 序可以調用這些服務功能,這樣擴展了自己系統(tǒng)的市場占有率,往大的概念上吹,就是所謂的SOA應用。
其實可以從多個角度來理解 WebService,從表面上看,WebService就是一個應用程序向外界暴露出一個能通過Web進行調用的API,也就是說能用編程的方法通過 Web來調用這個應用程序。我們把調用這個WebService的應用程序叫做客戶端,而把提供這個WebService的應用程序叫做服務端。從深層次 看,WebService是建立可互操作的分布式應用程序的新平臺,是一個平臺,是一套標準。它定義了應用程序如何在Web上實現(xiàn)互操作性,你可以用任何 你喜歡的語言,在任何你喜歡的平臺上寫Web service ,只要我們可以通過Web service標準對這些服務進行查詢和訪問。
WebService平臺需要一套協(xié)議來實現(xiàn)分布式應用程序的創(chuàng)建。任何平臺都有它的數據表示方法和類型系統(tǒng)。要實現(xiàn)互操作性,WebService平臺 必須提供一套標準的類型系統(tǒng),用于溝通不同平臺、編程語言和組件模型中的不同類型系統(tǒng)。Web service平臺必須提供一種標準來描述 Web service,讓客戶可以得到足夠的信息來調用這個Web service。最后,我們還必須有一種方法來對這個Web service進行遠 程調用,這種方法實際是一種遠程過程調用協(xié)議(RPC)。為了達到互操作性,這種RPC協(xié)議還必須與平臺和編程語言無關。
三、WebService平臺技術
XML+XSD,SOAP和WSDL就是構成WebService平臺的三大技術。
3.1、XML+XSD
WebService采用HTTP協(xié)議傳輸數據,采用XML格式封裝數據(即XML中說明調用遠程服務對象的哪個方法,傳遞的參數是什么,以及服務對象的 返回結果是什么)。XML是WebService平臺中表示數據的格式。除了易于建立和易于分析外,XML主要的優(yōu)點在于它既是平臺無關的,又是廠商無關 的。無關性是比技術優(yōu)越性更重要的:軟件廠商是不會選擇一個由競爭對手所發(fā)明的技術的。
XML解決了數據表示的問題,但它沒有定義一套標準的數據類型,更沒有說怎么去擴展這套數據類型。例如,整形數到底代表什么?16位,32位,64位?這 些細節(jié)對實現(xiàn)互操作性很重要。XML Schema(XSD)就是專門解決這個問題的一套標準。它定義了一套標準的數據類型,并給出了一種語言來擴展這套數據類型。WebService平臺就 是用XSD來作為其數據類型系統(tǒng)的。當你用某種語言(如VB.NET或C#)來構造一個Web service時,為了符合WebService標準,所 有你使用的數據類型都必須被轉換為XSD類型。你用的工具可能已經自動幫你完成了這個轉換,但你很可能會根據你的需要修改一下轉換過程。
3.2、SOAP
WebService通過HTTP協(xié)議發(fā)送請求和接收結果時,發(fā)送的請求內容和結果內容都采用XML格式封裝,并增加了一些特定的HTTP消息頭,以說明 HTTP消息的內容格式,這些特定的HTTP消息頭和XML內容格式就是SOAP協(xié)議。SOAP提供了標準的RPC方法來調用Web Service。
SOAP協(xié)議 = HTTP協(xié)議 + XML數據格式
SOAP協(xié)議定義了SOAP消息的格式,SOAP協(xié)議是基于HTTP協(xié)議的,SOAP也是基于XML和XSD的,XML是SOAP的數據編碼方式。打個比 喻:HTTP就是普通公路,XML就是中間的綠色隔離帶和兩邊的防護欄,SOAP就是普通公路經過加隔離帶和防護欄改造過的高速公路。
3.3、WSDL
好比我們去商店買東西,首先要知道商店里有什么東西可買,然后再來購買,商家的做法就是張貼廣告海報。 WebService也一樣,WebService客戶端要調用一個WebService服務,首先要有知道這個服務的地址在哪,以及這個服務里有什么方 法可以調用,所以,WebService務器端首先要通過一個WSDL文件來說明自己家里有啥服務可以對外調用,服務是什么(服務中有哪些方法,方法接受 的參數是什么,返回值是什么),服務的網絡地址用哪個url地址表示,服務通過什么方式來調用。
WSDL(Web Services Description Language)就是這樣一個基于XML的語言,用于描述Web Service及其函數、參數和返回值。它是WebService客戶端和服務器端都 能理解的標準格式。因為是基于XML的,所以WSDL既是機器可閱讀的,又是人可閱讀的,這將是一個很大的好處。一些最新的開發(fā)工具既能根據你的 Web service生成WSDL文檔,又能導入WSDL文檔,生成調用相應WebService的代理類代碼。
WSDL 文件保存在Web服務器上,通過一個url地址就可以訪問到它。客戶端要調用一個WebService服務之前,要知道該服務的WSDL文件的地址。 WebService服務提供商可以通過兩種方式來暴露它的WSDL文件地址:1.注冊到UDDI服務器,以便被人查找;2.直接告訴給客戶端調用者。
四、WebService開發(fā)
WebService開發(fā)可以分為服務器端開發(fā)和客戶端開發(fā)兩個方面
4.1、服務端開發(fā)
把公司內部系統(tǒng)的業(yè)務方法發(fā)布成WebService服務,供遠程合作單位和個人調用。(借助一些WebService框架可以很輕松地把自己的業(yè)務對象發(fā)布成WebService服務,Java方面的典型WebService框架包括:axis,xfire,cxf 等,java ee服務器通常也支持發(fā)布WebService服務,例如JBoss。)
4.2、客戶端開發(fā)
調用別人發(fā)布的WebService服務,大多數人從事的開發(fā)都屬于這個方面,例如,調用天氣預報WebService服務。(使用廠 商的WSDL2Java之類的工具生成靜態(tài)調用的代理類代碼;使用廠商提供的客戶端編程API類;使用SUN公司早期標準的jax-rpc開發(fā)包;使用 SUN公司最新標準的jax-ws開發(fā)包。當然SUN已被ORACLE收購)
4.3、WebService 的工作調用原理
對客戶端而言,我們給這各類WebService客戶端API傳遞wsdl文件的url地址,這些API就會創(chuàng)建出底層的代理類,我調用 這些代理,就可以訪問到webservice服務。代理類把客戶端的方法調用變成soap格式的請求數據再通過HTTP協(xié)議發(fā)出去,并把接收到的soap 數據變成返回值返回。對服務端而言,各類WebService框架的本質就是一個大大的Servlet,當遠程調用客戶端給它通過http協(xié)議發(fā)送過來 soap格式的請求數據時,它分析這個數據,就知道要調用哪個java類的哪個方法,于是去查找或創(chuàng)建這個對象,并調用其方法,再把方法返回的結果包裝成 soap格式的數據,通過http響應消息回給客戶端。
五、適用場合
1、跨防火墻通信
如果應用程序有成千上萬的用戶,而且分布在世界各地,那么客戶端和服務器之間的通信將是一個棘手的問題。因為客戶端和服務器之間通常會有防火墻或者代理服 務器。在這種情況下,使用DCOM就不是那么簡單,通常也不便于把客戶端程序發(fā)布到數量如此龐大的每一個用戶手中。傳統(tǒng)的做法是,選擇用瀏覽器作為客戶 端,寫下一大堆ASP頁面,把應用程序的中間層暴露給最終用戶。這樣做的結果是開發(fā)難度大,程序很難維護。如果中間層組件換成WebService的話, 就可以從用戶界面直接調用中間層組件。從大多數人的經驗來看,在一個用戶界面和中間層有較多交互的應用程序中,使用WebService這種結構,可以節(jié) 省花在用戶界面編程上20%的開發(fā)時間。
2、應用程序集成
企業(yè)級的應用程序開發(fā)者都知道,企業(yè)里經常都要把用不同語言寫成的、在不同平臺上運行的各種程序集成起來,而這種集成將花費很大的開發(fā)力量。應用程序經常 需要從運行在IBM主機上的程序中獲取數據;或者把數據發(fā)送到主機或UNIX應用程序中去。即使在同一個平臺上,不同軟件廠商生產的各種軟件也常常需要集 成起來。通過WebService,可以很容易的集成不同結構的應用程序。
3、B2B集成
用WebService集成應用程序,可以使公司內部的商務處理更加自動化。但當交易跨越供應商和客戶、突破公司的界限時會怎么樣呢?跨公司的商務交易集成通常叫做B2B集成。WebService是B2B集成成功的關鍵。通過WebService,公司可以把關鍵的商務應用“暴露”給指定的供應商和客戶。例如,把電子下單系統(tǒng)和電子發(fā)票系統(tǒng)“暴露”出來,客戶就可以以電子的方式發(fā)送訂單,供應商則可以以電子的方式發(fā)送原料采購發(fā)票。當然,這并不是一個 新的概念,EDI(電子文檔交換)早就是這樣了。但是,WebService的實現(xiàn)要比EDI簡單得多,而且WebService運行在Internet 上,在世界任何地方都可輕易實現(xiàn),其運行成本就相對較低。不過,WebService并不像EDI那樣,是文檔交換或B2B集成的完整解決方案。 WebService只是B2B集成的一個關鍵部分,還需要許多其它的部分才能實現(xiàn)集成。
用WebService來實現(xiàn)B2B集成的最大好處在于可以輕易實現(xiàn)互操作性。只要把商務邏輯“暴露”出來,成為WebService,就可以讓任何指定 的合作伙伴調用這些商務邏輯,而不管他們的系統(tǒng)在什么平臺上運行,使用什么開發(fā)語言。這樣就大大減少了花在B2B集成上的時間和成本,讓許多原本無法承受 EDI的中小企業(yè)也能實現(xiàn)B2B集成。
4、軟件和數據重用
軟件重用是一個很大的主題,重用的形式很多,重用的程度有大有小。最基本的形式是源代碼模塊或者類一級的重用,一種形式是二進制形式的組件重用。采用 WebService應用程序可以用標準的方法把功能和數據“暴露”出來,供其它應用程序使用,達到業(yè)務級重用。
六、不適用場合
1、單機應用程序
目前,企業(yè)和個人還使用著很多桌面應用程序。其中一些只需要與本機上的其它程序通信。在這種情況下,最好就不要用WebService,只要用本地的 API就可以了。COM非常適合于在這種情況下工作,因為它既小又快。運行在同一臺服務器上的服務器軟件也是這樣。最好直接用COM或其它本地的API來 進行應用程序間的調用。當然WebService也能用在這些場合,但那樣不僅消耗太大,而且不會帶來任何好處。
2、局域網的同構應用程序
在許多應用中,所有的程序都是用VB或VC開發(fā)的,都在Windows平臺下使用COM,都運行在同一個局域網上。例如,有兩個服務器應用程序需要相互通 信,或者有一個Win32或WinForm的客戶程序要連接局域網上另一個服務器的程序。在這些程序里,使用DCOM會比SOAP/HTTP有效得多。與 此相類似,如果一個.NET程序要連接到局域網上的另一個.NET程序,應該使用.NETremoting。有趣的是,在.NETremoting 中,也可以指定使用SOAP/HTTP來進行WebService調用。不過最好還是直接通過TCP進行RPC調用,那樣會有效得多。
以上是“WebService的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!