在以前的ASP時候,當請求一個*.asp分頁檔的時候,這個HTTP請求首先會被一個名為inetinfo.exe進程所截獲,這個進程實際上就是www服務。截獲之後它會將這個請求轉交給asp.dll進程,這個進程就會解釋這個asp頁面,然後將解釋後的資料流返回給用戶端瀏覽器。其實ASP.DLL是一個依附在IIS的ISAPI檔案,它負責了對諸如ASP檔案,ASA等檔案的解釋執行,
-------------------------------------
ASP.NET的HTTP請求處理方法
當用戶端向web伺服器請求一個*.aspx的分頁檔時,同asp類似,這個http請求也會被inetinfo.exe進程截獲(www服務),它判斷檔案尾碼之後,把這個請求轉交給ASPNET_ISAPI.DLL而ASPNET_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 --> HttpHandler Factory --> HttpHandler
當系統內部的HttpHandler的ProcessRequest方法處理完畢之後,整個Http Request就被處理完成了,用戶端也就得到相應的東東了。
完整的http請求在asp.net framework中的處理流程:
HttpRequest-->inetinfo.exe->ASPNET_ISAPI.DLL-->Http Pipeline-->ASPNET_WP.EXE-->HttpRuntime-->HttpApplication Factory-->HttpApplication-->HttpModule-->HttpHandler Factory-->HttpHandler-->HttpHandler.ProcessRequest()
如果想在中途截獲一個httpRequest並做些自己的處理,就應該在HttpRuntime運行時內部來做到這一點,確切的說時在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中配置的,和我們開發時使用到的web.config的關係是:是在ASP.NET FRAMEWORK啟動處理一個Http Request的時候,它會依次載入machine.config和請求頁面所在目錄的web.config檔案,如果在machine中配置了一個自己的HttpModule,你仍然可以在所在頁面的web.config檔案中remove掉這個映射關係。
public class HelloWorldModule : IHttpModule
{
public HelloWorldModule()
{
}
public String ModuleName
{
get { return "HelloWorldModule"; }
}
// In the Init function, register for HttpApplication
// events by adding your handlers.
public void Init(HttpApplication application)
{
application.BeginRequest +=
(new EventHandler(this.Application_BeginRequest));
application.EndRequest +=
(new EventHandler(this.Application_EndRequest));
}
private void Application_BeginRequest(Object source,
EventArgs e)
{
// Create HttpApplication and HttpContext objects to access
// request and response properties.
HttpApplication application = (HttpApplication)source;
HttpContext context = application.Context;
context.Response.Write("
HelloWorldModule: Beginning of Request
");
}
private void Application_EndRequest(Object source, EventArgs e)
{
HttpApplication application = (HttpApplication)source;
HttpContext context = application.Context;
context.Response.Write("
HelloWorldModule: End of Request
");
}
public void Dispose()
{
}
}
-----------------------------------------------------------------------------------
深入HttpModule
一個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容器進行調度和管理的,這樣做的優點是大大增強了系統的負荷性,提升了效率。
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/21aspnet/archive/2009/02/02/3857963.aspx