一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

WCF、Net remoting、Web service概念及區別

  Windows通信基礎(Windows Communication Foundation,WCF)是基于Windows平臺下開發和部署服務的軟件開發包(Software Development Kit,SDK)。

  WCF就是微軟對于分布式處理的 編程技術的集大成者,它將DCOM、Remoting、Web Service、WSE、MSMQ集成在一起,從而降低了分布式系統開發者的學習曲線,并統一了開發標準。

  WCF是建立在.NET Framework 2.0基礎之上的,包含在.NET 3.0/3.5當中。2005中并沒有包含WCF,但是當安裝好了WinFX Runtime Components后,我們就可以在Visual Studio 2005環境下開發和創建WCF的程序了。

  尊重資料來源。以下來自網頁http://www.cppblog.com/mzty/archive/2007/10/24/35068.html
  一 WCF
  概括地說,WCF具有如下的優勢:

  1、統一性

  前面已經敘述,WCF是對于ASMX,.NET Remoting,Enterprise Service,WSE,MSMQ等技術的整合。由于WCF完全是由托管代碼編寫,因此開發WCF的應用程序與開發其它的.NET應用程序沒有太大的區別,我們仍然可以像創建面向對象的應用程序那樣,利用WCF來創建面向服務的應用程序。

  2、互操作性

  由于WCF最基本的通信機制是SOAP,這就保證了系統之間的互操作性,即使是運行不同的上下文中。這種通信可以是基于.NET到.NET間的通信。

  可以跨進程、跨機器甚至于跨平臺的通信,只要支持標準的Web Service,例如J2EE應用服務器(如WebSphere,WebLogic)。應用程序可以運行在Windows操作系統下,也可以運行在其他的操作系統,如Sun Solaris,HP Unix,Linux等等。

  3、安全與可信賴

  WS-Security,WS-Trust和WS-SecureConversation均被添加到SOAP消息中,以用于用戶認證,數據完整性驗證,數據隱私等多種安全因素。

  在SOAP的header中增加了WS-ReliableMessaging允許可信賴的端對端通信。而建立在WS-Coordination和WS-AtomicTransaction之上的基于SOAP格式交換的信息,則支持兩階段的事務提交(two-phase commit transactions)。

  上述的多種WS-Policy在WCF中都給與了支持。對于Messaging而言,SOAP是Web Service的基本協議,它包含了消息頭(header)和消息體(body)。在消息頭中,定義了WS-Addressing用于定位SOAP消息的地址信息,同時還包含了MTOM(消息傳輸優化機制,Message Transmission Optimization Mechanism)。

  4、兼容性

  WCF充分的考慮到了與舊有系統的兼容性。安裝WCF并不會影響原有的技術如ASMX和.NET Remoting。即使對于WCF和ASMX而言,雖然兩者都使用了SOAP,但基于WCF開發的應用程序,仍然可以直接與ASMX進行交互。 

  二 WebService的運行機理

  首先客戶端從服務器的到WebService的WSDL,同時在客戶端聲稱一個代理類(Proxy Class), 這個代理類負責與WebService服務器進行Request 和Response, 當一個數據(XML格式的)被封裝成SOAP格式的數據流發送到服務器端的時候,就會生成一個進程對象并且把接收到這個Request的SOAP包進行解析,然后對事物進行處理,處理結束以后再對這個計算結果進行SOAP包裝,然后把這個包作為一個Response發送給客戶端的代理類(Proxy Class),同樣地,這個代理類也對這個SOAP包進行解析處理,繼而進行后續操作。

  三 .NET Remoting

  是在DCOM等基礎上發展起來的一種技術,它的主要目的是實現跨平臺、跨語言、穿透企業防火墻,這也是他的基本特點,與WebService有所不同的是,它支持HTTP以及TCP信道,而且它不僅能傳輸XML格式的SOAP包,也可以傳輸傳統意義上的二進制流,這使得它變得效率更高也更加靈活。而且它不依賴于IIS,用戶可以自己開發(Development)并部署(Dispose)自己喜歡的宿主服務器,所以從這些方面上來講WebService其實上是.NETemoting的一種特例。

  區別:

  1、Remoting可以靈活的定義其所基于的協議,比如http,tcp等,如果定義為HTTP,則與Web Service相同,但是webservice是無狀態的,使用remoting一般都喜歡定義為TCP,這樣比Web Service稍為高效一些,而且是有狀態的。

  2、Remoting不是標準,而Web Service是標準。

  3、Remoting一般需要通過一個WinForm或是Windows服務進行啟動,也可以使用iis部署,而Web Service則必須在IIS進行啟動。

  4、在VS.NET開發環境中,專門對Web Service的調用進行了封裝,用起來比Remoting方便。

  5 NET remoting只能應用于MS 的.NET framework之下,需要客戶端必須安裝framework,但是WebService是平臺獨立的,跨語言(只要能支持XML的語言都可以) 以及穿透企業防火墻。

  分布式應用程序設計:ASP.NET Web 服務和 .NET Remoting

  ASP.NET Web 服務偏向于 XML Schema 類型系統,提供具有廣泛使用范圍的跨平臺支持的簡單編程模型。.NET Remoting 偏向于運行時類型系統,提供較為復雜而且使用范圍小得多的編程模型。這種本質上的差別是決定使用哪種技術的主要因素。但是,還要考慮很多其他設計因素,包括傳輸協議、主機進程、安全性、性能、狀態管理以及對事務的支持等。

  傳輸協議和主機進程

  盡管 SOAP 規范并不要求用 HTTP 作為傳輸協議,但是客戶端只能通過 HTTP 訪問使用 ASP.NET Web 服務實現的 Web 服務,因為它是 ASP.NET 支持的唯一一種傳輸協議。服務是通過 IIS 調用的,并在 ASP.NET 的輔助進程 ASPNET_wp.exe 中執行。

  .NET Remoting 使您能夠在任何類型的應用程序(包括 Windows 窗體、托管的 Windows 服務、控制臺應用程序或 ASP.NET 輔助進程)中靈活地托管遠程對象。正如前面所述,.NET Remoting 提供兩個傳輸信道——TCP 和 HTTP。這兩個信道都能使用套接字提供任意發送和接收進程之間的通信。

  它還能將 HTTP 信道與 IIS 和 ASP.NET 輔助進程集成。這一點很重要,原因有以下幾點。首先,它是當客戶端請求到達時自動啟動 .NET Remoting 端點的唯一方法。.NET Remoting 管線不包括啟動遠程服務器所需的 DCOM 類型的服務控制管理器 (SCM)。如果從任意進程中提供遠程對象,則需要確保那些進程正在運行。還必須確保它們是線程安全的,例如,線程 A 不能在線程 B 開始關閉進程之后激活對象。如果從 ASP.NET 提供遠程對象,則可以利用 ASPNET_wp.exe 輔助進程,這樣既可自動啟動又具有線程安全的優勢。第二,與 IIS 集成是確保跨進程 .NET Remoting 調用的唯一途徑,如下一節所述。

  ASP.NET Web 服務和 .NET Remoting 基礎結構都是可擴展的。您可以過濾入站和出站消息,從多方面控制類型封送和元數據的生成。使用 .NET Remoting,還能實現您自己的格式化程序和信道。

  安全性

  由于 ASP.NET Web 服務依賴于 HTTP,因此它們與標準的 InterNET 安全性基礎結構相集成。ASP.NET 利用 IIS 的安全性功能,為標準 HTTP 驗證方案(包括基本、簡要、數字證書,甚至 Microsoft? .NET Passport)提供了強有力的支持。(還可以使用 Windows 集成驗證,但只能用于信任域中的客戶端。)使用可用的 HTTP 驗證方案的一個優勢在于,無需在 Web 服務中更改代碼,IIS 是在 ASP.NET Web 服務被調用之前執行驗證的。ASP.NET 還支持基于 .NET Passport 的驗證和其他自定義的驗證方案。ASP.NET 支持基于目標 URL 的訪問控制,并通過與 .NET 代碼訪問安全性 (CAS) 基礎結構的集成支持訪問控制。SSL 可用于確保通信的安全。

  盡管這些標準傳輸技術對于確保 Web 服務相當有效,但它們只能做到這種程度。在涉及到不同信任域中多個 Web 服務的復雜情況下,還得建立自定義的特殊解決方案。Microsoft 和其他公司正致力于創建一套安全性規范,該規范將基于 SOAP 消息的可擴展性提供消息級別的安全性功能。這些規范之一是 XML Web 服務安全性語言(WS-Security),它為消息級別的憑據傳輸、消息完整性和消息保密定義了框架。

  正如上一節所述,一般情況下,.NET Remoting 管線不能確保跨進程調用的安全。使用 ASP.NET 托管于 IIS 中的 .NET Remoting 端點可以利用 ASP.NET Web 服務可用的所有安全性功能,包括對使用 SSL 確保有線通信的安全性的支持。如果您正在使用托管在進程中的 TCP 信道或 HTTP 信道(而不是 ASPNET_wp.exe),則必須自己執行身份驗證、授權和保密機制。

  另一個要關注的安全性問題是,在不必更改默認安全性策略的情況下,從不完全信任的環境中執行代碼的能力。ASP.NET Web 服務客戶端代理可以在這些環境中工作,但 .NET Remoting 代理則不能。要從不完全信任的環境中使用 .NET Remoting 代理,需要特殊的序列化權限。默認情況下,該權限不會授予從 IntraNET 或 InterNET 上下載的代碼。如果要在不完全信任的環境中使用 .NET Remoting 客戶端,則需要更改從那些區域中加載的代碼的默認安全性策略。當您從運行于沙箱(如下載的 Windows 窗體應用程序)中的客戶端連接到系統時,ASP.NET Web 服務是較簡單的選擇,因為不需要更改安全性策略。

  狀態管理

  默認情況下,ASP.NET Web 服務模型采用無狀態的服務結構;它并不是本能地與來自同一個用戶的多個調用相關。另外,客戶端每次調用 ASP.NET Web 服務時,都創建一個新的對象以服務于該請求。方法調用完成后,該對象即被破壞。要維護請求之間的狀態,可以使用 ASP.NET 頁面使用的相同技術(例如,Session 和 Application 屬性包),也可以自己實現自定義的解決方案。

  .NET Remoting 支持許多狀態管理選項,并且可能與來自同一個用戶的多個調用相關或不相關,這取決于您選擇的對象生命周期架構。SingleCall 對象是無狀態的(如用于調用 ASP.NET Web 服務的對象),Singleton 對象共享所有客戶端的狀態,客戶端激活的對象在每個客戶端的基礎上保持狀態(帶有其產生的所有相關的可升級性和可靠性問題)。

  性能

  從原始性能方面來講,使用 TCP 信道和二進制格式化程序時,.NET Remoting 管線能夠提供最快的通信。在我們進行的比較 ASP.NET Web 服務和 .NET Remoting 的相對性能的幾乎所有的測試中,ASP.NET Web 服務在性能上都超出了使用 HTTP 或 TCP 信道的 SOAP 格式化程序的 .NET Remoting 端點。更有意思的是,使用二進制格式化程序和 HTTP 信道的 ASP.NET 和 .NET Remoting 端點在性能上非常相近。(更多信息,請參見 Performance Comparison:NET Remoting vs. ASP.NET Web Services。)

  企業服務

  ASP.NET Web 服務或通過 .NET Remoting 提供的對象可以使用本地事務根據單個數據庫協調工作。如果需要根據多個資源協調工作,可以使用 .NET 企業服務(又稱 COM+)公布的事務(由 COM+ 管線管理的 DTC 分布式事務)。但要注意的是,ASP.NET Web 服務和 .NET Remoting 管線都不能傳播公布的事務,因此兩種端點都不可能通過跨進程的調用繼承公布的事務。

  這不一定是件壞事。一般來講,公布的事務比本地事務代價要高,而要跨進程傳播公布的事務,則代價會更高。如果確實需要這一功能,簡單的解決方案是在 .NET 企業服務的服務器應用程序中部署一個從 System.EnterpriseServices.ServicedComponent 派生的類(更多信息,請參見 COM+ Integration:How .NET Enterprise Services Can Help You Build Distributed Applications)。對該類對象的跨進程調用將使用 DCOM 進行處理,以確保正確傳播事務環境。較難的解決方案是使用底層的 API,手動傳播分布的事務。

  值得注意的是,傳統的分布式事務模型一般不適用于松散耦合的 Web 服務。基于補償事務的模型(即,撤消其他事務所提交工作的事務)更有意義,因為其隔離約束條件并不是很嚴格。在包括 Microsoft 的 Web 服務供應商中有一種普遍的說法,即 Web 服務空間需要的事務模型越靈活,該空間中進行的工作越多。等到定義出 Web 服務事務的標準方法時,您就可以根據情況使用本地或公布的事務實現自己的補償架構了。

  小結

  雖然 .NET Remoting 基礎結構和 ASP.NET Web 服務都可以進行跨進程通信,但每種設計適用于不同的用戶。ASP.NET Web 服務提供了簡單的編程模型,并具有廣泛的使用范圍。.NET Remoting 提供了較為復雜的編程模型,而且使用范圍窄得多。請務必了解這兩種技術的工作原理,并選擇適合您應用程序的技術。在任意一種情況下,都要使用 IIS 和 ASP.NET 管理進程生命周期,并提供一般的安全性。

  我采用Remoting技術也是項目的需要:

  1、Remoteing主要用于C/S結構項目。

  2、將Remoting采用TCP通訊,比Web Service不是稍微高效一些,而是高幾倍,甚至幾十倍,不愧為是在DCOM等基礎上發展起來的技術。對于跨地區,乃至跨省(廣域網)的分布式應用,效率的高低意味著軟件系統的生死存亡。

  我在博客上說的這個三層結構,本意也只是在.NET環境下,利用反射技術、對象關系映射等技術,寫一個底層點的程序集,方便編寫數據庫訪問程序。該程序集要能封裝常用的數據庫操作。這個程序集不管是在Remoting、Web Service還是WCF,應該都能用的。就象我們在大學課本里學數據結構,學的是一種思想。如果只是單純局限一種技術,在日新月異的發展中,終將淘汰。我們都是凡人,不可能掌握所有技術。適合自己項目需要的,就是最好的!

NET技術WCF、Net remoting、Web service概念及區別,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲射图 | 男女午夜性爽快免费视频不卡 | 国产手机在线精品 | 2021精品国内一区视频自线 | 国产中文在线视频 | 国产日韩欧美91 | 激情网页 | 久热爱精品视频在线观看久爱 | ririai99在线视频观看 | 欧美播播| 国产欧美一区二区精品性色 | 美女三级在线 | 亚洲国产成人精品小蝌蚪 | 第一页欧美 | 春色视频一区二区三区 | 色黄大片| 黄色影院在线观看视频 | 国产麻豆91网在线看 | 91热视频 | 五月四房| 色多多www | 国产在线播放一区 | 91中文字幕视频 | 国产精品深夜福利免费观看 | 色播视频在线播放 | 精品福利影院 | 人人公开免费超级碰碰碰视频 | 中文字幕在线播放一区 | 国产精品短篇二区 | 五月婷花 | 国产永久免费视频 | 国产福利亚洲 | 国产欧美曰韩一区二区三区 | 国产免费91 | 国产成人青草视频 | 午夜福利国产一级毛片 | 亚洲国产精选 | 国产成人综合亚洲亚洲欧美 | 亚洲www | 久久er国产精品免费观看8 | 亚洲线精品一区二区三区 |