ASP.NET HttpModule——原理

iDotNetSpace發表於2009-01-12

一、Asp.Net執行過程

    當客戶端向web伺服器請求一個*.aspx的頁面檔案時,同asp類似,這個http請求也會被inetinfo.exe程式截獲(www服務),它判斷檔案字尾之後,把這個請求轉交給ASPNET_ISAPI.DLLASPNET_ISAPI.DLL則會通過一個Http PipeLine的管道,將這個http請求傳送給ASPNET_WP.EXE程式,當這個HTTP請求進入ASPNET_WP.EXE程式之後,asp.net framework就會通過HttpRuntime來處理這個Http請求,處理完畢後將結果返回給客戶端。

     

    當一個http請求被送入到HttpRuntime之後,這個Http請求會繼續被送入到一個被稱之為HttpApplication Factory的一個容器當中,而這個容器會給出一個HttpApplication例項來處理傳遞進來的http請求,而後這個Http請求會依次進入到如下幾個容器中:HttpModule --&gt HttpHandler Factory --&gt HttpHandler

    當系統內部的HttpHandlerProcessRequest方法處理完畢之後,整個Http Request就被處理完成了,客戶端也就得到相應的東東了。


    完整的http請求在asp.net framework中的處理流程:
         HttpRequest--&gtinetinfo.exe->ASPNET_ISAPI.DLL--&gtHttp Pipeline--&gtASPNET_WP.EXE--&gtHttpRuntime--&gtHttpApplication Factory--&gtHttpApplication--&gtHttpModule--&gtHttpHandler Factory--&gtHttpHandler--&gtHttpHandler.ProcessRequest()
   

    如果想在中途截獲一個httpRequest並做些自己的處理,就應該在HttpRuntime執行時內部來做到這一點,確切的說時在HttpModule這個容器中做到這個的。

二、HttpModule介紹

    系統本身的HttpModule實現一個IHttpModule的介面,當然我們自己的類也能夠實現IHttpModule介面,這就可以替代系統的HttpModule物件了。
ASP.NET
系統中預設的HttpModule:

      DefaultAuthenticationModule 確保上下文中存在 Authentication 物件。無法繼承此類。
      FileAuthorizationModule 驗證遠端使用者是否具有訪問所請求檔案的 NT 許可權。無法繼承此類。
      FormsAuthenticationModule 啟用 ASP.NET 應用程式以使用 Forms 身份驗證。無法繼承此類。
      PassportAuthenticationModule 提供環繞 PassportAuthentication 服務的包裝。無法繼承此類。
      SessionStateModule    為應用程式提供會話狀態服務。
      UrlAuthorizationModule    提供基於 URL 的授權服務以允許或拒絕對指定資源的訪問。無法繼承此類。
      WindowsAuthenticationModule 啟用 ASP.NET 應用程式以使用 Windows/IIS 身份驗證。無法繼承此類

     這些系統預設的HttpModule是在檔案machine.config中配置的,系統會在最初始由ASP.NET FRAMEWORK首先載入machine.config中的HttpModule和我們開發時使用到的web.config的關係是:是在ASP.NET FRAMEWORK啟動處理一個Http Request的時候,它會依次載入machine.config和請求頁面所在目錄的web.config檔案,如果在machine中配置了一個自己的HttpModule,你仍然可以在所在頁面的web.config檔案中remove掉這個對映關係。

三、延伸閱讀

    一個Http請求在被ASP.NET Framework捕獲之後會依次交給HttpModule以及HttpHandler來處理。hm與hh之間不是完全獨立的,實際上,http請求在hm傳遞的過程中會在某個事件內將控制權轉交給hh的,而真正的處理HttpHandler中執行完成後,HttpHandler會再次將控制權交還給HttpModule

    HttpModule的Init()中的引數是HttpApplication型別,它具有許多事件,包括BeginRequest,EndRequest,AuthentiacteRequest 等等。

    IHttpHandler
    它是asp.net Framework提供的一個介面,定義瞭如果要實現一個Http請求的處理所需要必須實現的一些系統約定。也就是說,如果你想要自行處理某些型別的HTTP請求資訊流的話,你需要實現這些系統約定才能做到。譬如一個*.aspx檔案,用來處理此型別的Http請求,ASP.NET FRAMEWORK將會交給一個名為System.Web.UI.PageHandlerFactory的HttpHandler類來處理。

     HH和HM一樣,系統會在最初始由ASP.NET FRAMEWORK首先載入machine.config中的HttpHandler,而後會載入Web應用程式所在目錄的web.config中的使用者自定義的HttpHandler類。但是系統與我們自定義的HH之間的關係是"覆蓋"的,也就是說如果我們自定義了一個針對"*.aspx"的HttpHandler類的話,那麼系統會將對此http請求的處理權完全交給我們自己定義的這個HttpHandler類來處理,而我們自己的HttpHandler類則需要自己完全解析這個Http請求,並作出處理。


     IHttpHandler介面中最重要的方法ProcessRequest,這個方法就是HttpHandler用來處理一個Http請求,當一個Http請求經過由HttpModule容器傳遞到HttpHandler容器中的時候,framework會呼叫HttpHandler的ProcessRequest方法來做對這個Http請求做真正的處理。
   

    framework實際上並不是直接把相關頁面的HTTP請求定位到一個內部預設的IHttpHandler容器之上的,而是定位到了其 內部預設的IHttpHandler Factory上了。IHttpHandler Factory的作用就是對很多系統已經實現了的IHttpHandler容器進行排程和管理的,這樣做的優點是大大增強了系統的負荷性,提升了效率。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12639172/viewspace-536502/,如需轉載,請註明出處,否則將追究法律責任。

相關文章