程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> 關於.NET >> 網絡服務提供了建立Microsoft.NET的基本模塊

網絡服務提供了建立Microsoft.NET的基本模塊

編輯:關於.NET

本文假定你已經熟悉了HTTP與XML 本文難度等級: 2

概要:網絡服務是基於網絡的分布式應用程序的基本構造模塊,而這些程序是以平台、對象模板和多語言方式構建的。網絡服務建立在象HTTP和XML之類的開放的Internet 標准之上的,並且形成了微軟的可編程網絡理念的基礎。

這篇文章詳細講述了網絡服務以及為其提供保證的技術,這些技術能確保服務被集成到應用程序裡去。接下來敘述了新的Microsoft .NET框架及它對生成和使用網絡服務的支持。

現在最緊迫的挑戰是應用程序的集成化:獲取運行在不同操作系統上的不同的應用程序――它們是由使用不同編程語言的對象模板建立的,然後把它們轉化為易於使用的網絡應用程序。建立在象HTTP和XML之類開放的網絡標准之上的網絡服務接受了這項挑戰。

但是只支持標准協議是不夠的,必須有途徑來生成、部署、擴展和維護這些網絡服務,這正是Microsoft? .NET框架要解決的問題。

本文描述了網絡服務及Microsft .NET框架 的組件,包括通用運行語言(common language runtime),服務框架和用於建立、集成網絡服務的程序模板。

網絡服務一覽

通常說來,一個網絡服務只是一個作為服務――通過Internet標准此服務能與其它網絡服務集成在一起――發行的簡單的應用程序。換句話說,它是可通過URL定位的自動將信息返回到需要它的客戶端那裡的一種資源。網絡服務一個重要的特點是客戶不需要知道一種服務是怎樣實現的。在本節中,我將向你解釋網絡及網絡服務如何把基於組件技術的最好的方面結合在一起的,並且介紹與網絡服務通信所需的基本框架。

同組件一樣,網絡服務提供“黑匣子”函數,它可以被再次作用而不用關心此服務是怎樣實現的。網絡服務提供被稱為契約的精確定義的接口,此接口描繪了所提供的服務。開發人員可以將遠程服務、本地服務和定置代碼組合在一起而集成應用程序。例如,某公司可以使用如下服務組建一在線商店:微軟護照(原文:Passport)服務以驗證用戶身份,第三方個人化服務以使網頁匹配每一個用戶的參數,信用卡處理服務,銷售稅服務,對每個運輸公司的包裹跟蹤服務,鏈接公司內部庫存管理程序的內部目錄服務,以及少量定置代碼以使他們的商店能脫穎而出。

然而,網絡服務與現在的組件技術不同,它不使用需要在服務器和客戶機有明確的、同類型基本構架的具體的對象模型協議,例如DCOM、 RMI或 IIOP 。盡管與具體組件技術緊密結合的實現在一個受控的環境中能很好地被接受,但它們在網絡環境中變得不切實際。因為一個集成商業程序的參與者會發生變化,隨著時間的推移,技術也在變化,所以在所有參與者間確保一個單一的、統一的體系架構就變得十分困難。網絡服務采取了另外一種途徑,它使用普便存在的網絡協議和數據格式,如HTTP和XML,進行通信。支持這些網絡標准的任何系統都支持網絡服務。

而且,網絡服務契約描述的是以術語報文形式提供的服務,這些服務是由網絡服務生成和接受的,而不是描述服務是如何實現的。通過把重點放在報文上,網絡服務模板就完全對語言、平台和對象模板一無所知。 用任何一套編程語言、對象模型和平台的完全特性集,都可實現網絡服務。網絡 服務可在任何平台被用任何語言所實現的應用程序使用。只要用於解釋服務容量、報文序列和所期望協議的契約得到認同,那麼所實現的網絡服務及網絡服務用戶就可相互不同,而不會影響會話另一端的應用程序。

網絡服務模板對最小體系架構的要求很低,以確保網絡服務在使用任何技術和編程語言的平台上實現和訪問。對網絡服務互用性的解決可只依靠網絡標准。然而,為了使應用程序更容易使用網絡服務,簡單地同意通過標准網絡協議就可以訪問網絡服務是不夠的。當網絡服務和網絡服使用者依靠標准的方式表示數據和命令、表示網絡服務契約 、算出網絡服務所提供的容量時,網絡服務才容易使用。

XML是定義一個標准的、可擴展的用於提供命令和典型數據的語言明顯的一種選擇。雖然為表示命令和典型數據可以定義使用其它技巧(比如編碼為一種查詢字符串)的規則,但XML被專門設計為描述數據的標准元語言。簡單對象存取協議(SOAP)是以一種可擴展的方式使用XML表示數據和命令的工業標准。網絡服務可選擇用SOAP決定報文的格式。從發表在2000年8月那期《MSDN Magazine》上的Rob Caron的文章中,你可以學到更多有關SOAP和SOAP Toolkit for Visual Studio? 6.0 的知識(見“開發網絡服務:與Visual Studio開發的SOAP Toolkit運行”)。

XML是網絡服務契約的一種使能技術。服務契約語言 (SCL)是記錄網絡服務契約的XML語法。由於SCL是基於XML的,所以對開發者和開發工具來說,容易生成、解釋契約。關於SCL細則的草案很快會出台(注意:現在的SOAP Toolkit for Visual Studio 6.0支持稱為SDL的SCL的早期版本)。

Disco 規范為服務提供者發布網絡 服務契約和相應的機制描述了一個標准方式,這將使開發者或開發工具可找到契約文獻。當你讀到這裡時, Disco規范的草案應出台了。

象SOAP, SCL和Disco這樣的標准有助於開發者,因為它們不需要明白和實現所使用的每一個網絡服務的訪問方式。支持這些標准的更好的、已充分測試的、高性能的體系架構將由開發平台提供,這會大大簡化整個開發過程。

Microsoft .NET Framework

Microsoft .NET框架的目的是使你更容易建立網絡應用程序和網絡服務。建立在操作系統最上層的服務,是管理運行時代碼需求的common language runtime,這些代碼可以用任何現代編程語言所寫。Runtime提供了許多服務,這些服務有助於簡化代碼開發和應用程序的開發同時也將提高應用程序的可靠性。.NET Framework包括一套可被開發者用於任何編程語言的類庫。在此之上是許多應用程序模板,這些模板特定地為開發網絡站點和網絡服務提供高級組件和服務。下面我將一層層地描述。

Common Language Runtime

運行語言(runtime)調入並運行用任何運行感知編程語言所寫的代碼。以運行為目標的代碼被稱為受控(managed )代碼,受控代碼代碼只是意味著在內部可執行代碼與運行自身間存在已定義好的合作契約。對於象生成對象、調用方法等這樣的任務,被委托給了運行語言,這使得在運行語言能為可執行代碼增加額外的服務。

運行語言以交叉語言集成、自描述組件、簡單配制和版本化及集成安全服務為特點。下面將快速查看一下每一特點。

運行語言使用一種新的能表達大部分現代編程語言語義的通用類型系統,通用類型系統定義了一套標准類型及生成新標准的規則。運行語言知道怎樣生成、執行這些類型。編譯器和解釋器使用運行語言服務定義類型、管理對象、進行方法調用,而不是使用工具或特定於語言的方法。

類型系統的主要設計目的是使多種語言能深度集成。用一種語言所寫的代碼能繼承用另一種語言所寫的類的實現,用一種語言所寫的代碼拋出的異常能被用另一種語言寫的代碼捕獲,象調試和剖析之類的操作會在完全封閉下工作,而不用考慮代碼所用的語言。這就意味著編寫可重用類庫的開發者,不再需要為每一種編程語言或編譯器生成一個版本,並且使用類庫的開發者不再受到為他們使用的編程語言開發的庫的限制。

自描述組件――現在Microsoft .NET框架上已成為可能――簡化了開發和配制,並提高了系統的可靠性。我解釋一下它是怎樣工作的。許多由運行語言提供的服務是由元數據及用於補充可執行代碼的信息所驅動。因為所有的信息都儲存在一起,只有可執行的(代碼)才被稱為自描述組件。

自描述組件的一個主要優點是,使用它們並不需要其它文件。類的定義不需要單獨的頭文件;通過檢查元數據對類的定義可以從組件自身獲得。跨語言或過程邊界訪問組件並不需要各自的IDL文件、類型文件或proxy/stubs;所必需的信息已存在於元數據之中。為識別開發者請示的服務屬性,並不需要展開各自的配制信息。 最主要的是,由於元數據是在編譯過程中由源代碼生成,並與可執行代碼儲存在一起,它將永遠和可執行部分同步。

除了改善對單個組件的配制,Microsft .NET框架定義了一個應用程序配制模板,以解決定置應用程序安裝和DLL版本化(通常被稱為“DLL Hell”)這一復雜過程的問題,運行語言提供了支持這個模板的服務。

Microsft .NET框架 引入了組合體的概念。一個組合體是一組資源和類型,並包括有關這些資源和類型的元數據,也就是被作為一個單元配制的。元數據被稱為組合體的名單,它包含象類型和資源表之類能被組合體外看得見的信息,這個名單也包括有關從屬關系之類的信息,例如組合體建立時的版本號。開發人員可以指定版本策略,以指示運行語言是否裝入系統上已安裝的依賴於組合體的最新版本,裝入一指定版本,或在編譯時使用的版本。

某軟件組件的多個拷貝總可以存在於同樣的操作系統上,然而,通常說來,只有其中的一個拷貝能被操作系統注冊、調入內存、執行。對系統來說,定位和調入內存的策略是全局性。.NET Framework common language runtime 增加了所必須的體系架構以支持管理組件定位和調入的每個應用程序策略,這通常被稱為並行配制。

組合體可以被一個應用程序私有,或被多個應用程序共享。一個組合體的多個版本可以同時配制在同一台機器上。應用程序配制信息定義了到何處去查找組合體,這樣runtime就能為同時運行的兩個不同的應用程序裝入同一組合體的不同版本。這就消除了由組件版本的不兼容性引起的問題,提高了系統整體的穩定性。如果必要,如果必要,管理員可以為配制時刻的組合體增加配制信息,例如一個不同的版本策略,但是編譯時提供的原始信息永遠不會丟失。

因為組合體是自描述的,所以並不需要在系統上進行顯式注冊。應用程序的配制簡單到只需將文件拷貝到目錄中既可(如果為了使應用程序能夠運行,必須安裝未經組織過的組件的話,情況會稍微復雜一點)。配制信息保存在可被任何文本編輯器編輯的XML文件中。

最後,運行語言也提供完整的、普遍深入的安全服務,以確保未經授權的用戶不能訪問機器上的資源,並且代碼不會執行未經允許的動作。這就提高了系統整體的安全性可靠性。 由於運行語言用於裝入代碼、生成對象、執行方法調用,所以當受控代碼裝入內存、執行時,運行語言能進行安全檢查,強化安全策略。

Microsft .NET框架不僅規定代碼訪問安全,還規定基於角色的安全。通過代碼訪問安全機制,開發人員能為應用程序指定完成工作所必需的權限。例如,代碼或許需要寫文件或訪問環境變量的權力。這類信息和有關代碼標志的信息一起存儲在配制級上的。當代碼裝入內存及執行方法調用時,運行語言驗證是否能給予代碼所要求的權限。如果不能,將記錄一條安全沖突信息。給予權限的策略,這被稱為信任策略,是由系統管理員建立的,並且是建立在關於代碼的證據基礎之上,比如:代碼是誰發布的,是從什麼地方獲得的,以及在組合體中找到的代碼標志和它要求的權限。開發人員可以指定他們顯然不需要的權限,以防止其它人惡意使用他們的代碼。如果所需要的權限依賴直到運行時刻才會知道的信息,那麼就可寫入綱鄰性的安全檢查。

除了代碼訪問安全,運行語言還支持基於角色的安全。基於角色的安全建立同代碼訪問安全一樣的權限模板,只是這些權限是建立在用戶的身份之上,而不是建立在代碼的標志之上。角色表明了用戶所屬的類,並且可以在開發和配制階段定義。給予權限的策略被分配到每個預定義的角色。在運行時刻,用戶的身份被確定,代碼將代表這個身份運行。運行語言決定用戶是哪個角色的成員,然後給予基於這個角色的權限。

在查看Microsft .NET框架的可編程模板前,先看一下它所提供的服務。

服務框架

在common language runtime之上是服務框架,此框架提供能被任何現代編程語言調用的類。所有的類都遵循一套命名和設計方針,以大大減小開發人員的學習上的彎路。

框架包括一套開發人員希望在標准語言庫中存在的基類庫,例如:集合、輸入/輸出,字符串及數據類。另外,基類庫提供訪問操作系統服務如圖畫、網絡、線程、全球化和加密的類。服務框架也包括數據訪問類庫,及開發工具,如調試和剖析服務,能夠使用的類。本文章沒有詳細討論所有的類,我將重點放在數據訪問類上,因為大多數網絡服務需要對數據的訪問。當然,你可以在Microsoft .NET Framework SDK中找到關於服務框架類庫的附加信息。

數據訪問服務

幾乎所有的網絡服務都需要查詢和更新永久性數據,不論是以簡單文件,還是以相關數據庫,或是以其它的存儲類型存在。為了提供對數據的訪問,服務框架包括ActiveX? Data Objects+ (ADO+)類庫。如同名子所暗示地那樣,ADO+由ADO發展而來。ADO+被設計為基於網絡的可擴展的應用程序和服務提供數據訪問服務。ADO+為連接的指針風格的數據訪問,同時也為更適合於把數據返回到客戶端應用程序的無連接的數據模板提供高性能的APIs流,就象在以後介紹的那樣。圖4 闡明了ADO+的體系結構,表明任何數據,不論這些數據實際上如何存儲的,都以XML或相關數據的格式被操作,不論是哪一種格式,在一個給定的時間點上對應用程序都是最合適的。

就象其余幾個部分一樣,ADO+定義了那些鏈接數據倉庫、 對數據倉庫發送命令及從中獲取結果的類。這些類由受控數據提供者(managed data provider)實現。ADO+中鏈接和命令對象看上去和ADO中的是一樣的,並且一個名為DataReader的新類提供了通過高性能A

表單應用模板

從概念上講,在服務框架的最上面是兩個應用程序模板:Windows?應用程序模板和網絡應用程序模板。盡管我把重點放在把微軟.NET 框架用作開發網絡服務和網絡應用程序的一種途徑上,但框架也可用於開發較傳統的基於Windows的應用程序(當然,這些應用程序也能使用網絡服務)。

編寫Windows客戶應用程序的開發人員可使用Win表單應用程序模板以利用Windows豐富的用戶接口特點,包括現在的ActiveX控件和Windows 2000的新特點,如透明的、分層的、浮動窗口。可以選擇傳統的Windows或網絡外觀。得知它和現在的基於Windows表單包的相似性以後,開發人員會發現Win表單可編程模板和對設計階段的支持非常直觀。

Win 表單利用了Microsft .NET框架 runtime以減少基於Windows的客戶應用程序的開銷。只要應用程序和組件是用Win所寫或被Win表單應用程序使用,那麼它們就能被框架安全模板在客戶機上安全地執行。如果以這種方式使用或執行,那麼某人從Internet下載下來的生猛游戲就不會對配制信息和數據產生破壞,否則會自動地給用戶地址薄裡的每一個人發送電子郵件。

Microsft .NET框架 裝配模板簡化了應用程序的配制和版本化 。應用程序可被配制為使用它們在編譯和測試所用的共享組件,而不是使用恰好在客戶機器上安裝的隨便什麼版本的組件,這就提高了應用程序的可靠性,減少了應用程序所支持調用的主要因素:用戶接口控件和其它共享組件版本的不兼容性。

結論

網絡服務為在Internet上綁定應用程序提供了一個利用現存體系架構和應用程序的簡單的、靈活的、基於許多標准的模型。網絡應用程序很容易與當地開發的服務或已存在的服務集成在一起,而不用考慮開發平台、開發語言或使用的對象模型,以用於實現任何組成的服務或應用程序。

Microsft .NET框架在現有開發人員技巧之上,提供了一個應用程序模板和關鍵技術,用於簡化安全、可靠、可擴展、高可用性的網絡服務的建立、部署和不斷的發展。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved