作为一个Asp.Net平台开发者,非常有必要了解IIS和Asp.Net是如何结合,执行我们的托管代码,以及Asp.Net管道事件的.
本节目录
IIS 5.x
InetInfo.exe与W3SVC服务
IIS 5.x运行在进程InetInfo.exe中,在该进程中一个最重要的服务就是名为World Wide Web Publishing Service(简称W3SVC)的Windows Service。
W3SVC的主要功能包括HTTP请求的监听、工作进程的管理以及配置管理(通过从Metabase中加载相关配置信息)等。
请求资源(根据扩展名区分静态和动态资源)
静态文件,直接返回文件内容。
动态资源,通过扩展名从IIS的脚本影射(Script Map)找到相应的ISAPI Dll。
ISAPI
ISAPI是Internet服务器API(Internet Server Application Programming Interface)的缩写.是IIS和其他应用的纽带.
ISAPI包括ISAPI Extension和ISAPI Filter
ISAPI Extension
不用种类的动态资源,会有不同的ISAPI扩展.
如Asp.Net(.aspx .asmx .svc等)则为aspnet_isapi.dll。在目录“%windir%\Microsoft.NET\Framework\{version no}\”中找到该dll。
ISAPI Filter
Filter则可以在HTTP请求真正被处理之前查看、修改、转发或者拒绝请求,比如IIS可以利用ISAPI筛选进行请求的验证(Authentication)。
请求Asp.Net
如果我们请求的是一个基于ASP.NET的资源:
说明:
IIS 6
IIS5的不足
IIS6解决办法
另外在IIS6中,创建新的http监听器:HTTP协议栈(HTTP Protocol Stack,HTTP.SYS)
请求Asp.Net
与IIS5.X不同的是:
1.W3SVC服务根据请求创建工作进程
2.aspnet_isapi.dll是在工作进程的初始化过程中被加载。
说明:
IIS 7+
W3SVC服务
在IIS6中的W3SVC服务的功能
在IIS7中W3SVC只负责第一个功能,剩余功能交给WAS服务管理
WAS服务
IIS7引入Windows进程激活服务(Windows Process Activation Service,WAS):同时处理HTTP和非HTTP请求。
在WAS中,定义了一个重要的接口:监听器适配器接口(Listener Adapter Interface)抽象出不同协议监听器监听到的请求。
WAS将监听W3SVC服务的http请求以及WCF服务的TCP、Named Pipes、MSMQ3种请求.
说明
WCF提供的这3种监听器和监听适配器定义在程序集SMHost.exe中,你可以通过下面的目录找到该程序集:%windir%\Microsoft.NET\Framework\v3.0\Windows Communication Foundation。
SMHost.exe提供了4个重要的Windows Service:
集成模式
传统模式的缺点
集成模式
实际上IIS7集成模式,就是让用户可以通过编写托管代码的module,把托管代码插入到IIS内核代码中来解析,方便大家精确控制任意请求,带来更好的扩展性。
(这里面每个静态文件也会经过生命周期事件,执行效率肯定会有所下降.)
配置文件上的区别
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<!--传统模式-->
<
system.web
>
<
customErrors
mode="RemoteOnly">
<
error
statusCode="404" redirect="404.html"/>
<
error
statusCode="500" redirect="500.html"/>
</
customErrors
>
<
compilation
debug="true" targetFramework="4.5" />
<
httpRuntime
targetFramework="4.5" />
</
system.web
>
<!--集成模式-->
<
system.webServer
>
<
httpErrors
errorMode="DetailedLocalOnly">
<
clear
/>
<
error
path="404.html" statusCode="404"/>
<
error
path="500.html" statusCode="500"/>
</
httpErrors
>
</
system.webServer
>
|
Asp.Net管道
扩展
HttpModule
从功能上讲,HttpModule之于ASP.NET,就好比ISAPI Filter之于IIS一样。IIS将接收到的请求分发给相应的ISAPI Extension之前,注册的ISAPI Filter会先截获该请求。
如果说HttpModule相当于IIS的ISAPI Filter的话,我们可以说HttpHandler则相当于IIS的ISAPI Extension,HttpHandler在ASP.NET中扮演请求的最终处理者的角色。
当请求转入ASP.NET管道后,最终负责处理该请求的是与请求资源类型相匹配的HttpHandler对象,但是在Handler正式工作之前,ASP.NET会先加载并初始化所有配置的HttpModule对象。HttpModule在初始化的过程中,会将一些功能注册到HttpApplication相应的事件中,那么在HttpApplication整个请求处理生命周期中的某个阶段,相应的事件会被触发,通过HttpModule注册的事件处理程序也得以执行。
所有的HttpModule都实现了IHttpModule接口.
1
2
3
4
5
6
7
8
9
|
namespace
System.Web
{
public
interface
IHttpModule
{
void
Init(HttpApplication context);
void
Dispose();
}
}
|
系统定义的HttpModule
自定义HttpMoudle
HttpHandle
对于不同资源类型的请求,ASP.NET会加载不同的Handler来处理,也就是说.aspx page与.asmx web service对应的Handler是不同的。
所有的HttpHandler都实现了接口IHttpHandler。
1
2
3
4
5
6
|
public
interface
IHttpHandler
{
bool
IsReusable {
get
; }
void
ProcessRequest(HttpContext context);
}
|
系统定义的HttpHandle
WebForm的aspx文件:System.Web.UI.Page
WCF的svc文件:System.ServiceModel.Activation.HttpHandler
MVC:MVCHandler
自定义HttpHandle
由于Handle是在PostMapRequestHandler前和 PostResolveRequestCache 后映射指定的Handle,
所以我们可以在PostResolveRequestCache事件中注册我们的Handle.
在PreRequestHandlerExecute 后将会调用我们的Handle.PR方法.
扩展
HttpApplication主要有19个事件,通过我的网站任意地址+参数即可访问所有事件。
+?pipe可以查看这些事件触发时间.如:http://neverc.cn?pipe
+?pe可以附带我的网站内容:http://neverc.cn?pe
猜猜如何实现出以上效果