1. 程式人生 > >WebService到底是什麼?(保證看一遍就懂)

WebService到底是什麼?(保證看一遍就懂)

一、序言

  大家或多或少都聽過WebService(Web服務),有一段時間很多計算機期刊、書籍和網站都大肆的提及和宣傳WebService技術,其中不乏很多吹噓和做廣告的成分。但是不得不承認的是WebService真的是一門新興和有前途的技術,那麼WebService到底是什麼?何時應該用?

   當前的應用程式開發逐步的呈現了兩種迥然不同的傾向:一種是基於瀏覽器的瘦客戶端應用程式,一種是基於瀏覽器的富客戶端應用程式(RIA),當然後一種技術相對來說更加的時髦一些(如現在很流行的Html5技術),這裡主要講前者。

   基於瀏覽器的瘦客戶端應用程式並不是因為瘦客戶能夠提供更好的使用者介面,而是因為它能夠避免花在桌面應用程式釋出上的高成本。釋出桌面應用程式成本很高,一半是因為應用程式安裝和配置的問題,另一半是因為客戶和伺服器之間通訊的問題。傳統的Windows富客戶應用程式使用DCOM來與伺服器進行通訊和呼叫遠端物件。配置好DCOM使其在一個大型的網路中正常工作將是一個極富挑戰性的工作,同時也是許多IT工程師的噩夢。事實上,許多IT工程師寧願忍受瀏覽器所帶來的功能限制,也不願在區域網上去執行一個DCOM。關於客戶端與伺服器的通訊問題,一個完美的解決方法是使用HTTP協議來通訊。這是因為任何執行Web瀏覽器的機器都在使用HTTP協議。同時,當前許多防火牆也配置為只允許HTTP連線。許多商用程式還面臨另一個問題,那就是與其他程式的互操作性。如果所有的應用程式都是使用COM或.NET語言寫的,並且都執行在Windows平臺上,那就天下太平了。然而,事實上大多數商業資料仍然在大型主機上以非關係檔案(VSAM)的形式存放,並由COBOL語言編寫的大型機程式訪問。而且,目前還有很多商用程式繼續在使用C++、Java、Visual Basic和其他各種各樣的語言編寫。現在,除了最簡單的程式之外,所有的應用程式都需要與執行在其他異構平臺上的應用程式整合並進行資料交換。這樣的任務通常都是由特殊的方法,如檔案傳輸和分析,訊息佇列,還有僅適用於某些情況的的API,如IBM的高階程式到程式交流(APPC)等來完成的。在以前,沒有一個應用程式通訊標準,是獨立於平臺、組建模型和程式語言的。只有通過Web Service,客戶端和伺服器才能夠自由的用HTTP進行通訊,不論兩個程式的平臺和程式語言是什麼。

二、WebService到底是什麼?

   一言以蔽之:WebService是一種跨程式語言和跨作業系統平臺的遠端呼叫技術。

   所謂跨程式語言和跨操作平臺,就是說服務端程式採用java編寫,客戶端程式則可以採用其他程式語言編寫,反之亦然!跨作業系統平臺則是指服務端程式和客戶端程式可以在不同的作業系統上執行。

    所謂遠端呼叫,就是一臺計算機a上的一個程式可以呼叫到另外一臺計算機b上的一個物件的方法,譬如,銀聯提供給商場的pos刷卡系統,商場的POS機轉賬呼叫的轉賬方法的程式碼其實是跑在銀行伺服器上。再比如,amazon,天氣預報系統,淘寶網,校內網,百度等把自己的系統服務以webservice服務的形式暴露出來,讓第三方網站和程式可以呼叫這些服務功能,這樣擴充套件了自己系統的市場佔有率,往大的概念上吹,就是所謂的SOA應用。

   其實可以從多個角度來理解WebService,從表面上看,WebService就是一個應用程式向外界暴露出一個能通過Web進行呼叫的API,也就是說能用程式設計的方法通過Web來呼叫這個應用程式。我們把呼叫這個WebService的應用程式叫做客戶端,而把提供這個WebService的應用程式叫做服務端。從深層次看,WebService是建立可互操作的分散式應用程式的新平臺,是一個平臺,是一套標準。它定義了應用程式如何在Web上實現互操作性,你可以用任何你喜歡的語言,在任何你喜歡的平臺上寫Web service ,只要我們可以通過Web service標準對這些服務進行查詢和訪問。 

   WebService平臺需要一套協議來實現分散式應用程式的建立。任何平臺都有它的資料表示方法和型別系統。要實現互操作性,WebService平臺必須提供一套標準的型別系統,用於溝通不同平臺、程式語言和元件模型中的不同型別系統。Web service平臺必須提供一種標準來描述Web service,讓客戶可以得到足夠的資訊來呼叫這個Web service。最後,我們還必須有一種方法來對這個Web service進行遠端呼叫,這種方法實際是一種遠端過程呼叫協議(RPC)。為了達到互操作性,這種RPC協議還必須與平臺和程式語言無關。

三、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響應訊息回給客戶端。

五、適用場合

1、跨防火牆通訊:

   如果應用程式有成千上萬的使用者,而且分佈在世界各地,那麼客戶端和伺服器之間的通訊將是一個棘手的問題。因為客戶端和伺服器之間通常會有防火牆或者代理伺服器。在這種情況下,使用DCOM就不是那麼簡單,通常也不便於把客戶端程式釋出到數量如此龐大的每一個使用者手中。傳統的做法是,選擇用瀏覽器作為客戶端,寫下一大堆ASP頁面,把應用程式的中間層暴露給終端使用者。這樣做的結果是開發難度大,程式很難維護。如果中間層元件換成WebService的話,就可以從使用者介面直接呼叫中間層元件。從大多數人的經驗來看,在一個使用者介面和中間層有較多互動的應用程式中,使用WebService這種結構,可以節省花在使用者介面程式設計上20%的開發時間。

2、應用程式整合:

   企業級的應用程式開發者都知道,企業裡經常都要把用不同語言寫成的、在不同平臺上執行的各種程式整合起來,而這種整合將花費很大的開發力量。應用程式經常需要從執行在IBM主機上的程式中獲取資料;或者把資料傳送到主機或UNIX應用程式中去。即使在同一個平臺上,不同軟體廠商生產的各種軟體也常常需要整合起來。通過WebService,可以很容易的整合不同結構的應用程式。

3、B2B整合:

   用WebService整合應用程式,可以使公司內部的商務處理更加自動化。但當交易跨越供應商和客戶、突破公司的界限時會怎麼樣呢?跨公司的商務交易整合通常叫做B2B整合。WebService是B2B整合成功的關鍵。通過WebService,公司可以把關鍵的商務應用“暴露”給指定的供應商和客戶。例如,把電子下單系統和電子發票系統“暴露”出來,客戶就可以以電子的方式傳送訂單,供應商則可以以電子的方式傳送原料採購發票。當然,這並不是一個新的概念,EDI(電子文件交換)早就是這樣了。但是,WebService的實現要比EDI簡單得多,而且WebService執行在Internet上,在世界任何地方都可輕易實現,其執行成本就相對較低。不過,WebService並不像EDI那樣,是文件交換或B2B整合的完整解決方案。WebService只是B2B整合的一個關鍵部分,還需要許多其它的部分才能實現整合。

   用WebService來實現B2B整合的最大好處在於可以輕易實現互操作性。只要把商務邏輯“暴露”出來,成為WebService,就可以讓任何指定的合作伙伴呼叫這些商務邏輯,而不管他們的系統在什麼平臺上執行,使用什麼開發語言。這樣就大大減少了花在B2B整合上的時間和成本,讓許多原本無法承受EDI的中小企業也能實現B2B整合。

4、軟體和資料重用:

      軟體重用是一個很大的主題,重用的形式很多,重用的程度有大有小。最基本的形式是原始碼模組或者類一級的重用,一種形式是二進位制形式的元件重用。採用WebService應用程式可以用標準的方法把功能和資料“暴露”出來,供其它應用程式使用,達到業務級重用。

六、不適用場合

1、單機應用程式:

      目前,企業和個人還使用著很多桌面應用程式。其中一些只需要與本機上的其它程式通訊。在這種情況下,最好就不要用WebService,只要用本地的 API就可以了。COM非常適合於在這種情況下工作,因為它既小又快。執行在同一臺伺服器上的伺服器軟體也是這樣。最好直接用COM或其它本地的API來進行應用程式間的呼叫。當然WebService也能用在這些場合,但那樣不僅消耗太大,而且不會帶來任何好處。

2、區域網的同構應用程式:

      在許多應用中,所有的程式都是用VB或VC開發的,都在Windows平臺下使用COM,都執行在同一個區域網上。例如,有兩個伺服器應用程式需要相互通訊,或者有一個Win32或WinForm的客戶程式要連線區域網上另一個伺服器的程式。在這些程式裡,使用DCOM會比SOAP/HTTP有效得多。與此相類似,如果一個.NET程式要連線到區域網上的另一個.NET程式,應該使用.NETremoting。有趣的是,在.NETremoting 中,也可以指定使用SOAP/HTTP來進行WebService呼叫。不過最好還是直接通過TCP進行RPC呼叫,那樣會有效得多。

文章轉載出處:http://blog.csdn.net/wooshn/article/details/8069087/

相關推薦

WebService到底是什麼?(保證)

一、序言   大家或多或少都聽過WebService(Web服務),有一段時間很多計算機期刊、書籍和網站都大肆的提及和宣傳WebService技術,其中不乏很多吹噓和做廣告的成分。但是不得不承認的是WebService真的是一門新興和有前途的技術,那麼WebServic

維納濾波器---完必(不

首先我們討論一下什麼叫濾波器,一個濾波器就是一段含有噪聲的訊號,經過這個濾波器之後,變成了另一個訊號,只不過,這個訊號比較特殊,它和原來的訊號有聯絡,這個聯絡就是現在的訊號是原來訊號的+噪聲訊號。這就是輸出訊號,和輸入訊號的相關性。 既然濾波器就是這麼一個東西h(n),我們

會的CocoaPods的安裝和使用教程

什麼是CocoaPods? CocoaPods是專門為iOS工程提供對第三方庫的依賴的管理工具,通過CocoaPods,我們可以更方便地管理每個第三方庫的版本,而且不需要我們做太多的配置。直觀、集中和自動化地管理我們專案的第三方庫。 我們都有這樣的經歷,當我們新增第三方庫的時候,需要匯入一堆相關依賴庫,更

理解,圖解單鏈表反轉

前言 反轉連結串列是程式設計師必備的基本素養,經常在面試、筆試的過程中出現。一直覺得反轉連結串列實現程式碼不是很好理解,決定搬leetcode那道經典反轉連結串列題出來,用十多張圖去解析它,希望加深大家對連結串列反轉的理解,謝謝閱讀。 leetcode的反轉連結串列原題&答案 題目描述: 反轉一個單鏈

,我

1.ImportError: dlopen: cannot load any more object with static TLS Backend Qt5Agg is interactive backend. Turning interactive mode

23種設計模式——會了10種+

建立型1、工廠模式用過switch case吧,他就是最簡單的工廠模式2、抽象工廠模式用過maven吧,當你引用一個jar,他會關聯的給你一系列你需要下載的東西,但是你只需要寫一個配置就OK了,工廠裡面全都處理好了3、單例這個不多講了,一般都寫過,分3種,有空自己練練就好4、

new的過程是怎樣的?完這

在現實世界中,找物件是一門學問,找物件不在於多而在於精 ![](https://ask.qcloudimg.com/http-save/4159932/2h9uw2fosy.jpeg) 在計算機世界中,**面向物件程式設計**的關鍵在於能否靈活地運用類,如何設計出一個符合需求的物件也是也是值得學習和思考的

RESTful轉載,多理解了寫點自己的看法和理解

類型 delete 標識 class 請求 source 通用 添加 架構 要理解資源路由就要理解什麽是RESTful。如果一個架構符合REST(即Representational State Transfer的縮寫,意為表現層狀態轉化)原則,就稱它為RESTful架構。

比特幣是什麽-這邊你

比特幣 區塊鏈 對於比特幣也許一千個人有一千種理解。本文作為入門篇,我盡量用簡單易懂的語言來介紹比特幣。到底什麽是比特幣,它到底是怎麽運行的呢。比特幣是什麽比特幣是一種基於分布式網絡的數字貨幣。比特幣系統(廣義的比特幣)則是用來構建這種數字貨幣的網絡系統,是一個分布式的點對點網絡系統。本文主要講解狹義

vintage、遷移率、滾動率、入催率等概念——完你了(轉載)

聯網 edit ews 問題 目的 content 時間 客戶 clear 隨著互聯網金融的發展,對數據分析的需求越來越大。數據分析的目的其實是為了找到風險和收益的平衡點。高收益伴隨著高風險,而低風險的回報又如同雞肋。所以,太高的風險,太低的收益都不行

還沉浸在大公司就是螺絲釘小公司鍛鍊人?完你

剛畢業那會經歷過很多所謂創業公司,和很多朋友經歷過畫大餅,洗腦以及公司上市原始股這樣的承諾。當你正在趟過這些謊言你就會發現,在這個世界上能信這些鬼話的也只有涉世未深的畢業生了。小公司裡真的就是十幾二十幾個精英帶你一路向前?沒有辦公室政治?呵呵,金庸說過有人的地方就有江湖。在經濟下滑的今天小公

錯!不得不知的綜基命題陷阱

展鴻公職考試中心成立於2001年,是一家專注於國家公務員考試(http://www.gwyks.cn/html/gwy)考前輔導培訓和書籍研發的機構。專業的師資團隊、創新實效的課程模式,真心關懷的服務理念,選擇展鴻,助您成公! 事業單位綜合基礎知識的考試,分為

主席樹(靜態) 圖文講解讓你 hdu2665為例

主席樹 先介紹一下主席樹,主席樹也稱函式式線段樹也稱可持久化線段樹。(其實就是支援查詢歷史版本,這個在看完之後就會了解) 其實主席樹就是很多線段樹組合的總體,從它的其它稱呼也可以看出來了,其實它本質上還是線段樹。 主席樹就是利用函數語言程式設計的思想來使線段樹支

iOS--上線被拒如何從蘋果返回的崩潰日誌iOS.crash檔案處理找崩點(這篇了)

2017年底了,現在蘋果上線的越來越嚴,導致被拒的次數也是越來越特多。我們從蘋果給的提示可以看出我們大概崩潰的位置,但是作為程式設計師的我們,找到具體崩潰的點才能更好的修復。 AppStore稽核沒有通過,給了3個crashLog.txt檔案,可是開啟後都是十六進位制的東東(根本不知道

初學者如何從零開始學習人工智慧?完你

此文是想要進入人工智慧這個領域、但不知道從哪裡開始的初學者最佳的學習資源列表。   一、機器學習   有關機器學習領域的最佳介紹,請觀看Coursera的Andrew Ng機器學習課程。 它解釋了基本概念,並讓你很好地理解最重要的演算法。  

初學者如何從零學習人工智慧?完你

此文是想要進入人工智慧這個領域、但不知道從哪裡開始的初學者最佳的學習資源列表。 一、機器學習 有關機器學習領域的最佳介紹,請觀看Coursera的Andrew Ng機器學習課程。 它解釋了基本概念,並讓你很好地理解最重要的演算法。 “Programming Coll

機器學習十大演算法都是何方神聖?完你

轉自: http://tech.sina.com.cn/it/2016-12-24/doc-ifxyxury8364458.shtml 雷鋒網按:機器學習與人工智慧變得越來越熱。大資料原本在工業界中就已經炙手可熱,而基於大資料的機器學習則更加流行,因為其通過對資料的計算

BP神經網路計算過程詳解,用筆手算反向傳播

手算BP神經網路 現在很多人都說,做it門檻很低,腦子靈活點,願意去熬的,培訓個幾個月就可以,無非是調調函式而已。 確實,現在一些程式設計師的工作,調調函式掌握得好的話,也是能夠勝任的。但是,想要更進一步,還得不斷提升自己,努力理解各種演算法結構。 (類)

主席樹 (動態)圖文講解讓你 zoj2112為例

主席樹(動態) 其實靜態主席樹我們弄清楚之後,動態的可以很快學會。因為動態主席樹就是在靜態主席樹的基礎上增加了一批用樹狀陣列思維維護的線段樹。 我們以下面的例子講解。 5 3 3 2 1 4 7 Q 1 4 3 詢問區間[1,4]第3小數

劃分樹 圖文講解讓你 hdu2665為例

學主席樹的時候看到一篇部落格說是因為一個大牛當時不會劃分樹而想出的另一種解決區間第k小的問題,所以在學了主席樹之後我就學了下劃分樹。 劃分樹解決靜態區間第k小問題比主席樹的時空消耗都要少,不過好像不能解決動態區間第k小問題。 這篇部落格寫的非常好,所以我