ASP.NET中的HTTP模块和处理程序
介绍
在internet时代的开端,客户端的需求非常有限;.htm文件就可以满足他们的需求。但是,随着时间的流逝,客户端需求的扩充超越了.htm文件或静态文件所包含的功能。
开发者需要扩充或扩展web服务器的功能。web服务器厂商设计了不同的解决方案,但是都遵循同一个主题“向web服务器插入某些组件”。所有的web服务器补充技术都允许开发者建立并插入组件以增强web服务器的功能。微软公司提出了isapi(internet服务器api),网景公司提出了nsapi(网景服务器api)等等。
isapi是一种重要的技术,它允许我们增强与isapi兼容的web服务器(iis就是一种与isapi兼容的web服务器)的能力。我们使用下面的组件达到这个目的:
· isapi扩展
· isapi过滤器
isapi扩展是使用win32动态链接库来实现的。你可以把isapi扩展看作是一个普通的应用程序。isapi扩展的处理目标是http请求。这意味着你必须调用它们才能激活它们。 你可以认为isapi过滤器仅仅就是一个过滤器而已。客户端每次向服务器发出请求的时候,请求要经过过滤器。客户端不需要在请求中指定过滤器,只需要简单地把请求发送给web服务器,接着web服务器把请求传递给相关的过滤器。接下来过滤器可能修改请求,执行某些登录操作等等。
由于这些组件的复杂性,实现它们非常困难。开发者不得不使用c/c++来开发这些组件,但是对于很多人来说,使用c/c++进行开发简直就是痛苦的代名词。
那么asp.net提供什么东西来实现这些功能呢?asp.net提供的是httphandler(http处理程序)和httpmodule(http模块)。
在深入了解这些组件的详细信息之前,了解一下http请求经过http模块和http处理程序的时候的处理流程是有价值的。
建立示例应用程序
我建立了下面一些的c#项目以演示应用程序的不同组件:
· newhandler (http处理程序)
· webapp (演示http处理程序)
· securitymodules (http模块)
· webapp2 (演示http模块)
这些应用程序的安装步骤:
· 解开attached zip文件中的所以代码。
· 建立两个虚拟目录webapp和webapp2;把这两个目录指向webapp和webapp2应用程序的实际物理目录。
· 把newhandler项目中的newhandler.dll文件复制到webapp应用程序的bin目录。
· 把securitymodules项目中的securitymodules.dll文件复制到webapp2应用程序的bin目录中。
asp.net请求的处理过程
asp.net请求处理过程是基于管道模型的,在模型中asp.net把http请求传递给管道中的所有模块。每个模块都接收http请求并有完全控制权限。模块可以用任何自认为适合的方式来处理请求。一旦请求经过了所有http模块,就最终被http处理程序处理。http处理程序对请求进行一些处理,并且结果将再次经过管道中的http模块:
请注意在http请求的处理过程中,只能调用一个http处理程序,然而可以调用多个http模块。
http处理程序
http处理程序是实现了system.web.ihttphandler接口的.net组件。任何实现了ihttphandler接口的类都可以用于处理输入的http请求。http处理程序与isapi扩展有些类似。http处理程序和isapi扩展的差别在于在url中可以使用http处理程序的文件名称直接调用它们,与isapi扩展类似。
http处理程序实现了下列方法:
方法名称 | 描述 |
processrequest | 这个方法实际上是http处理程序的核心。我们调用这个方法来处理http请求。 |
isreusable | 我们调用这个属性来决定http处理程序的实例是否可以用于处理相同其它类型的请求。http处理程序可以返回true或false来表明它们是否可以重复使用。 |
你可以使用web.config或者machine.config文件把这些类映射到http请求上。映射完成以后,当接收到相应请求的时候asp.net会实例化http处理程序。我们将解释如何在web.config和/或machine.config文件中定义所有这些细节信息。
asp.net还通过ihttphandle易做图ctory接口支持http处理程序的扩展。asp.net提供了把http请求路由到实现ihttphandle易做图ctory接口的类的对象上的能力。此外,asp.net还利用了factory设计模式。这种模式为建立一组相关对象而不提供具体类的功能提供了接口。简单的说,你可以把用于建立依赖传递进来的参数建立的http处理程序对象的类看作是factory(工厂)。我们不用指定需要实例化的特定的http处理程序;http处理程序工厂处理这种事务。这样做的优点在于如果未来实现ihttphandler接口的对象的实现方法发生了改变,只要接口仍然相同,客户端就不会受到影响。
下面是ihttphandle易做图ctory接口中的方法列表:
方法名称 | 描述 |
gethandler | 这个方法负责建立适当的处理程序并把它的指针返回到调用代码(asp.net运行时)。这个方法返回的处理程序对象应该实现了ihttphandler接口。 |
releasehandler | 这个方法负责在请求处理完成后释放http处理程序。factory 实现决定了它的操作。factory 实现可以是实际摧毁实例,也可以把它放入缓冲池供以后使用。 |
在配置文件中注册http处理程序和http处理程序工厂
asp.net在下面的配置文件中维护自己的配置信息:
· machine.config
· web.config
machine.config文件包含应用于计算机上安装的所有web应用程序的配置设置信息。
web.config文件对于每个web应用程序来说是特定的。每个web应用程序都有自己的web.config文件。web应用程序的任何子目录也可能包含自己的web.config文件;这使得它们能够覆盖父目录的设置信息。
为了给我们的web应用程序添加http处理程序,你可以使用<httphandlers>和<add>节点。实际上,处理程序都带有<add>节点,列举在<httphandlers>和</httphandlers>节点之间。下面是添加http处理程序的一个普通的例子:
<httphandlers> <add verb="supported http verbs" path="path" type="namespace.classname, assemblyname" /> <httphandlers> |
在上面的xml中,
· verb属性指定了处理程序支持的http动作。如果某个处理程序支持所有的http动作,请使用“*”,否则使用逗号分隔的列表列出支持的动作。因此如果你的处理程序只支持http get和post,那么verb属性就应该是“get, post”。
· path属性指定了需要调用处理程序的路径和文件名(可以包含通配符)。例如,如果你希望自己的处理程序只有在test.xyz文件被请求的时候才被调用,那么path属性就包含“test.xyz”,如果你希望含有.xyz后缀的所有文件都调用处理程序,path属性应该包含“*.xyz”。
· type属性用名字空间、类名称和部件名称的组合形式指定处理程序或处理程序工厂的实际类型。asp.net运行时首先搜索应用程序的bin目录中的部件dll,接着在全局部件缓冲(gac)中搜索。
asp.net运行时对http处理程序的使用方式
无论你是否相信,asp.net都使用http请求实现了大量的自己的功能。asp.net使用处理程序来处理.aspx、 .asmx、 .soap和其它asp.net文件。
下面是machine.config文件中的一个片段:
<httphandlers> <add verb="*" path="trace.axd" type="system.web.handlers.tracehandler"/> <add verb="*" path="*.aspx" type="system.web.ui.pagehandle易做图ctory"/> <add verb="*" path="*.ashx" type="system.web.ui.易做图handle易做图ctory"/> <add verb="*" path="*.config" type="system.web.httpforbiddenhandler"/> <add verb="get,head" path="*" type="system.web.staticfilehandler"/> . . . . . . . . . . . . </httphandlers> |
在上面的配置信息中你可以看到对.aspx文件的所有请求都由system.web.ui.pagehandle易做图ctory类来处理。与此类似,对.config文件和其它文件(它们不能被客户端直接访问)的所有请求都由system.web.httpforbiddenhandler类处理。你可能已经猜到,当访问这些文件的时候,该类简单地给客户端返回一个错误信息。
执行http处理程序
现在你将看到如何实现一个http处理程序。那么我们的新处理程序要做什么任务呢?前面我提到,处理程序大多数用于给web服务器添加新功能;因此,我将建立一个处理程序来处理新的文件类型——扩展名为.15seconds的文件。我们建立了这个处理程序并在我们的web应用程序的web.config文件中注册之后,所有对.15seconds文件的请求都将由
补充:Web开发 , ASP.Net ,