WebService到底是什麼?
一言以蔽之:WebService是一種跨程式語言和跨作業系統平臺的遠端呼叫技術。
WebService平臺技術
XML+XSD,SOAP和WSDL就是構成WebService平臺的三大技術。
XML+XSD:
WebService採用HTTP協議傳輸資料,採用XML格式封裝資料(即XML中說明呼叫遠端服務物件的哪個方法,傳遞的引數是什麼,以及服務物件的返回結果是什麼)。XML是WebService平臺中表示資料的格式。除了易於建立和易於分析外,XML主要的優點在於它既是平臺無關的,又是廠商無關的。無關性是比技術優越性更重要的:軟體廠商是不會選擇一個由競爭對手所發明的技術的。
XML解決了資料表示的問題,但它沒有定義一套標準的資料型別,更沒有說怎麼去擴充套件這套資料型別。例如,整形數到底代表什麼?16位,32位,64位?這些細節對實現互操作性很重要。XML Schema(XSD)就是專門解決這個問題的一套標準。它定義了一套標準的資料型別,並給出了一種語言來擴充套件這套資料型別。WebService平臺就是用XSD來作為其資料型別系統的。當你用某種語言(如VB.NET或C#)來構造一個Web service時,為了符合WebService標準,所有你使用的資料型別都必須被轉換為XSD型別。你用的工具可能已經自動幫你完成了這個轉換,但你很可能會根據你的需要修改一下轉換過程。
SOAP:
WebService通過HTTP協議傳送請求和接收結果時,傳送的請求內容和結果內容都採用XML格式封裝,並增加了一些特定的HTTP訊息頭,以說明HTTP訊息的內容格式,這些特定的HTTP訊息頭和XML內容格式就是SOAP協議。SOAP提供了標準的RPC方法來呼叫Web Service。
SOAP協議 = HTTP協議 + XML資料格式
SOAP協議定義了SOAP訊息的格式,SOAP協議是基於HTTP協議的,SOAP也是基於XML和XSD的,XML是SOAP的資料編碼方式。打個比喻:HTTP就是普通公路,XML就是中間的綠色隔離帶和兩邊的防護欄,SOAP就是普通公路經過加隔離帶和防護欄改造過的高速公路。
WSDL:
好比我們去商店買東西,首先要知道商店裡有什麼東西可買,然後再來購買,商家的做法就是張貼廣告海報。 WebService也一樣,WebService客戶端要呼叫一個WebService服務,首先要有知道這個服務的地址在哪,以及這個服務裡有什麼方法可以呼叫,所以,WebService務器端首先要通過一個WSDL檔案來說明自己家裡有啥服務可以對外呼叫,服務是什麼(服務中有哪些方法,方法接受的引數是什麼,返回值是什麼),服務的網路地址用哪個url地址表示,服務通過什麼方式來呼叫。
WSDL(Web Services Description Language)就是這樣一個基於XML的語言,用於描述Web Service及其函式、引數和返回值。它是WebService客戶端和伺服器端都能理解的標準格式。因為是基於XML的,所以WSDL既是機器可閱讀的,又是人可閱讀的,這將是一個很大的好處。一些最新的開發工具既能根據你的Web service生成WSDL文件,又能匯入WSDL文件,生成呼叫相應WebService的代理類程式碼。
WSDL檔案儲存在Web伺服器上,通過一個url地址就可以訪問到它。客戶端要呼叫一個WebService服務之前,要知道該服務的WSDL檔案的地址。WebService服務提供商可以通過兩種方式來暴露它的WSDL檔案地址:1.註冊到UDDI伺服器,以便被人查詢;2.直接告訴給客戶端呼叫者。
WebService開發
WebService開發可以分為伺服器端開發和客戶端開發兩個方面:
服務端開發:把公司內部系統的業務方法釋出成WebService服務,供遠端合作單位和個人呼叫。(藉助一些WebService框 架可以很輕鬆地把自己的業務物件釋出成WebService服務,Java方面的典型WebService框架包括:axis,xfire,cxf等,java ee伺服器通常也支援釋出WebService服務,例如JBoss。)
客戶端開發:呼叫別人釋出的WebService服務,大多數人從事的開發都屬於這個方面,例如,呼叫天氣預報WebService服務。(使用廠商的WSDL2Java之類的工具生成靜態呼叫的代理類程式碼;使用廠商提供的客戶端程式設計API類;使用SUN公司早期標準的jax-rpc開發包;使用SUN公司最新標準的jax-ws開發包。當然SUN已被Oracle收購)
WebService的工作呼叫原理:對客戶端而言,我們給這各類WebService客戶端API傳遞wsdl檔案的url地址,這些API就會建立出底層的代理類,我呼叫這些代理,就可以訪問到webservice服務。代理類把客戶端的方法呼叫變成soap格式的請求資料再通過HTTP協議發出去,並把接收到的soap資料變成返回值返回。對服務端而言,各類WebService框架的本質就是一個大大的Servlet,當遠端呼叫客戶端給它通過http協議傳送過來soap格式的請求資料時,它分析這個資料,就知道要呼叫哪個java類的哪個方法,於是去查詢或建立這個物件,並呼叫其方法,再把方法返回的結果包裝成soap格式的資料,通過http響應訊息回給客戶端。