浅析IHttpModule和IHttpHandler

最近开发中涉及到一些使用IHttpModule和IHttpHandler,储备不够便到MSDN学习了一下。

 

这两个接口是怎么产生的呢,这恐怕要从IIS处理外部请求说起:

IIS本身无法处理动态页面,仅支持静态HTML页面,为了解决此问题引入了ISPAI机制,从字面理解就是一个API,这种机制有两种实现方式


IHttpModule:这个接口被赋予了ISAPI过滤器功能,通过对HttpApplication对象的一系列事件的处理来对Http处理管道施加影响,这些方法在HttpModule的Init事件中注册,通常会在webconfig文件中进行配置,也可以有多个HttpModule,执行顺序在webconfig中注册的顺序是一致的,而且每一个都会执行。但是IHttpHandler却是如果第一个适配后面的就不再重复执行,他的Init方法和Application_Start是不同的,HTTPRuntime维护着一个HttpApplication Pool而他是并发的所以多个用户访问可能会多次执行Init,而Application_Start这个方法只在服务器第一次启动时执行
IHttpHandler:他是实现了ISAPI扩展功能,可以自定义实现IHttpHandler,然后在IIS服务器重注册,进而实现自己喜欢的扩张名,别忘了在config文件中也注册

理解这个之后可以在处理HttpRequest之前就进行校验,而不是传统的挥发到页面在处理,这样的提前处理对海量访问的效率提高有好处 

一,IHttpModule

查看这个接口的代码可以发现,它是由两个方法组成:

public interface IHttpModule{   void Dispose();   void Init(HttpApplication context); }

看到两个方法及方法标签,就明白这个IHttpModule接口有什么作用了,Init方法中传入了一个HttpApplication参数,它提供对 ASP.NET 应用程序内所有应用程序对象的公用的方法、属性和事件的访问,包括了HttpApplication下的方法、属性和事件的访问。那么具体有那些呢?

image

包括了所有我们经常会用到的一些对象,Application,Context,Event,Modules,Request,Response,Server,Session,Site,User,BeginRequest,EndRequest等等,其中Context中有个一个方法Context.RewritePath可以用来重写URL的,也就是说只要你在App_code中添加一个继承IHttpModule接口的类,并在webconfig中添加此Module后,这个类就可以处理全局的应用程序所有的方法、属性和事件了。

这里针对URL重写做了个小测试

 

public   interface  IHttpHandler

{   

bool  IsReusable {  get ; }      

void  ProcessRequest(HttpContext context);    

}

 

 

 

IsReusable获取一个值,该值指示其他请求是否可以使用 System.Web.IHttpHandler 实例。

System.Web.HttpContext 对象,它提供对用于为 HTTP 请求提供服务的内部服务器对象(如 Request、Response、Session 和 Server)的引用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值