天天看點

ASP.NET底層架構之從浏覽器到ASP.NET

  讓我們從一個典型的ASP.NET Web請求的生命周期的起點開始。當使用者輸入一個URL,點選了一個超連結或者送出了一個HTML表單(form)(一個POST請求,相對于前兩者在一般意義上都是GET請求)。或者一個用戶端程式可能調用了一個基于ASP.NET的WebService(同樣由ASP.NET來處理)。在Web伺服器端,IIS5或6,獲得這個請求。在最底層,ASP.NET和IIS通過ISAPI擴充進行互動。在ASP.NET環境中這個請求通常被路由到一個擴充名為.aspx的頁面上,但是這個流程是怎麼工作的完全依賴于處理特定擴充名的HTTP Handler是怎麼實作的。在IIS中。aspx通過’應用程式擴充’(又稱為腳本映射)被映射到ASP.NET的ISAPI擴充DLL-aspnet_isapi.dll。每一個請求都需要通過一個被注冊到aspnet_isapi.dll的擴充名來觸發ASP.NET(來處理這個請求)。

  依賴于擴充名ASP.NET将請求路由到一個合适的處理器(handler)上,這個處理器負責擷取這個請求。例如,WebService的。asmx擴充名不會将請求路由到磁盤上的一個頁面,而是一個由特殊屬性(Attribute)标記為WebService的類上。許多其他處理器和ASP.NET安裝,當然你也可以自定義處理器。所有這些HttpHandler在IIS中被配置為指向ASP.NET ISAPI擴充,并在web。config(譯著:ASP.NET中自帶的handler是在machine。config中配置的,當然可以在web.config中覆寫配置)被配置來将請求路由到指定的HTTP Handler上。每個handler都是一個處理特殊擴充的。NET類,可以從一個簡單的隻包含幾行代碼的Hello World類,到非常複雜的handler如ASP.NET的頁面或者WebService的handler。目前,隻要了解ASP.NET的映射機制是使用擴充名來從ISAPI接收請求并将其路由到處理這個請求的handler上就可以了。

  對在IIS中自定義Web請求處理來說,ISAPI是第一個也是最高效的入口。

  ISAPI連接配接

  ISAPI是底層的非托管Win32 API。ISAPI定義的接口非常簡單并且是為性能做了優化的。它們是非常底層的-處理指針和函數指針表來進行回調-但是它們提供了最底層和面向效率的接口,使開發者和工具提供商可以用它來挂接到IIS上。因為ISAPI非常底層是以它并不适合來開發應用級的代碼,而且ISAPI傾向于主要被用于橋接接口,向上層工具提供應用伺服器類型的功能。例如,ASP和ASP.NET都是建立在ISAPI上的,Cold Fusion,運作在IIS上的多數Perl,PHP以及JSP實作,很多第三方解決方案(如我的Wisual FoxPro的Web連接配接架構)都是如此。ISAPI是一個傑出的工具,可以為上層應用提供高效的管道接口,這樣上層應用可以抽象出ISAPI提供的資訊。在ASP和ASP.NET中,将ISAPI接口提供的資訊抽象成了類型Request和Response這樣的對象,通過它們來讀取ISAPI請求中對應的資訊。将ISAPI想像成管道。對ASP.NET來說,ISAPI dll是非常的”瘦”的,隻是作為一個路由機制來将原始的請求轉發到ASP.NET運作時。所有那些沉重的負擔和處理,甚至請求線程的管理都發生在ASP.NET引擎内部和你的代碼中。

  作為最為協定,ISAPI同時支援ISAPI擴充和ISAPI過濾器(Filter)。擴充是一個請求處理接口,提供了處理Web伺服器的輸入輸出的邏輯-它本質上是一個處理(事物?)接口。ASP和ASP.NET都被實作為ISAPI擴充。ISAPI過濾器是挂接接口,提供了檢視進入IIS的每一個請求的能力,并能修改請求的内容或者改變功能型的行為,例如認證等。順便提一下,ASP.NET通過了兩種概念映射了類似ISAPI的功能:Http Handler類似擴充,Http Module類似過濾器。我們将在後面詳細讨論它們。

  ISAPI是開始一個ASP.NET請求的最初的入口。ASP.NET映射了好幾個擴充名到它的ISAPI擴充,此擴充位于。NET架構的目錄下:

  <.NET FrameworkDir>/aspnet_isapi.dll

  你可以在IIS服務管理界面上看到這些映射,如圖1。檢視網站根目錄的屬性中的主目錄配置頁,然後檢視配置|映射。

  

ASP.NET底層架構之從浏覽器到ASP.NET

  圖1:IIS映射了多種擴充名如。ASPX到ASP.NET的ISAPI擴充。通過這個機制請求會在Web伺服器這一層被路由到ASP.NET的處理管道。

  由于.NET需要它們中的一部分,你不應該設定手動這些擴充名。使用aspnet_regiis.exe這個工具來確定所有的映射都被正确的設定了:

  cd <.NetFrameworkDirectory>

  aspnet_regiis – i

  這個指令将為整個Web站點注冊特定版本的ASP.NET運作時,包括腳本 (擴充名) 映射和用戶端腳本庫(包括進行控件驗證的代碼等)。注意它注冊的是<.Net FrameworkDirectory>中安裝的特定版本的CLR(如1.1,2.0)。aspnet_regiis的選項令您可以對不同的虛拟目錄進行配置。每個版本的.NET架構都有自己不同版本的aspnet_regiis工具,你需要運作對應版本的aspnet_regiis來為web站點或者虛拟目錄來配置指定版本的。NET架構。從ASP.NET2.0開始提供了ASP.NET配置頁面,可以通過這個頁面在IIS管理控制台來互動的配置.NET版本