首页 > 代码库 > ASP.NET MVC请求处理管道生命周期的19个关键环节(1-6)

ASP.NET MVC请求处理管道生命周期的19个关键环节(1-6)

ASP.NET和ASP.NET MVC的HttpApplication请求处理管道有共同的部分和不同之处,本系列将体验ASP.NET MVC请求处理管道生命周期的19个关键环节。

 

  ①以IIS6.0为例,首先由w3wp.exe维护着一个工作进程


1

 

  ②如果是第一次加载,由Aspnet_isapi.dll加载.NET运行时


2

 

  ③一个工作进程里有一个应用程序池,其中可以承载多个应用程序域AppDomain


3

 

  ④HTTP.SYS接收请求,通过应用程序域工厂AppDomainFactory创建应用程序域AppDomain


4

 

  ⑤一个IsapiRuntime被加载,并创建一个IsapiWorkerRequest对象封装当前的HTTP请求,并把该IsapiWorkerRequest对象传递给ASP.NET的HttpRuntime运行时,此时,  HTTP请求开始进入ASP.NET请求管道


5

 

也就是说,HttpRuntime是ASP.NET请求管道的入口。当请求进来,首先进入HttpRuntime,由HttpRuntime来决定如何处理请求。默认情况下,在machine.config和Web.config中并没有显式定义httpRuntime节点,但该节点是有默认值的,如下:


<httpRuntime    apartmentThreading="false"   appRequestQueueLimit="5000"   delayNotificationTimeout="5"   enable="true"   enableHeaderChecking="true"   enableKernelOutputCache="true"   enableVersionHeader="true"   encoderType = "System.Web.Util.HttpEncoder"   executionTimeout="110"   maxQueryStringLength = "2048"   maxRequestLength="4096"   maxUrlLength = "260"   maxWaitChangeNotification="0"   minFreeThreads="8"   minLocalRequestFreeThreads="4"   relaxedUrlToFileSystemMapping = "False"   requestLengthDiskThreshold="80"   requestPathInvalidCharacters = "<,>,*,%,&,:,\"   requestValidationMode = "4.0"   requestValidationType = "System.Web.Util.RequestValidator"   requireRootedSaveAsPath="true"   sendCacheControlHeader="true"   shutdownTimeout="90"   useFullyQualifiedRedirectUrl="false"   waitChangeNotification="0" />

通常,我们可以在Web.config中更改httpRuntime节点的默认值,如下:

<configuration>  <system.web>  <httpRuntime maxRequestLength="4000"    enable = "True"    requestLengthDiskThreshold="512    useFullyQualifiedRedirectUrl="True"    executionTimeout="45"    versionHeader="1.1.4128"/>  </system.web></configuration>

 

  ⑥HttpRuntime维护着一个HttpApplication池,当有HTTP请求过来,从池中选取可用的HttpApplication处理请求


6

 

HttpApplication有19个管道事件,分别是:

1、BeginRequest:HTTP管道开始处理请求时,会触发BeginRequest事件2、AuthenticateRequest:安全模块对请求进行身份验证时触发该事件3、PostAuthenticateRequest:安全模块对请求进行身份验证后触发该事件4、AuthorizeRequest:安全模块对请求进程授权时触发该事件5、PostAuthorizeRequest:安全模块对请求进程授权后触发该事件6、ResolveRequestCache:缓存模块利用缓存直接对请求进程响应时触发该事件7、PostResolveRequestCache:缓存模块利用缓存直接对请求进程响应后触发该事件8、PostMapRequestHandler:对于访问不同的资源类型,ASP.NET具有不同的HttpHandler对其进程处理。对于每个请求,ASP.NET会根据扩展名选择匹配相应的HttpHandler类型,成功匹配后触发该事件9、AcquireRequestState:状态管理模块获取基于当前请求相应的状态(比如SessionState)时触发该事件10、PostAcquireRequestState:状态管理模块获取基于当前请求相应的状态(比如SessionState)后触发该事件11、PreRequestHandlerExecute:在实行HttpHandler前触发该事件12、PostRequestHandlerExecute:在实行HttpHandler后触发该事件13、ReleaseRequestState:状态管理模块释放基于当前请求相应的状态时触发该事件14、PostReleaseRequestState:状态管理模块释放基于当前请求相应的状态后触发该事件15、UpdateRequestCache:缓存模块将HttpHandler处理请求得到的相应保存到输出缓存时触发该事件16、PostUpdateRequestCache:缓存模块将HttpHandler处理请求得到的相应保存到输出缓存后触发该事件17、LogRequest:为当前请求进程日志记录时触发该事件18、PostLogReques:为当前请求进程日志记录后触发该事件19、EndRequest:整个请求处理完成后触发该事件

我们可以在全局配置文件Global.asax中,按照约定的规则Application_{Event Name}来对管道事件定制:

void Application_Start(object sender, EventArgs e) {}void Application_End(object sender, EventArgs e) {}void Application_Error(object sender, EventArgs e) {}void Session_Start(object sender, EventArgs e) {}void Session_End(object sender, EventArgs e) {}......

未完待续~~