`
hcmfys
  • 浏览: 347232 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

ASP.Net中自定义Http处理及应用之HttpModule篇 (转载)

    博客分类:
  • c#
阅读更多
HttpHandler实现了类似于ISAPI Extention的功能,他处理请求(Request)的信息和发送响应(Response)。HttpHandler功能的实现通过实现IHttpHandler接口来达到。而HttpModule实现了类似于ISAPI Filter的功能。

HttpModule的实现

HttpModules实现了类似于ISAPI Filter的功能,在开发上,通常需要经过以下步骤:

1.编写一个类,实现IhttpModule接口

2.实现Init 方法,并且注册需要的方法

3.实现注册的方法

4.实现Dispose方法,如果需要手工为类做一些清除工作,可以添加Dispose方法的实现,但这不是必需的,通常可以不为Dispose方法添加任何代码。

5.在Web.config文件中,注册您编写的类

下面是一个HttpModules的示例,在这个示例中,只是简单的注册了HttpApplication 的BeginRequest 和 EndRequest事件,并且通过这些事件的实现方法,将相关的信息打印出来。

<ccid_nobr><table bordercolordark="#ffffff" bordercolorlight="black" width="550" align="center" border="1" cellpadding="2" cellspacing="0"><tr> <td bgcolor="#e6e6e6"> <pre><ccid_code>例1:<br> using System;<br> using System.Web; <br> namespace MyModule<br> {<br> public class MyModule : IHttpModule <br> {<br> public void Init(HttpApplication application) <br> { <br> application.BeginRequest += (new <br> EventHandler(this.Application_BeginRequest));<br> application.EndRequest += (new <br> EventHandler(this.Application_EndRequest));<br> }<br> private void Application_BeginRequest(Object source, EventArgs e) <br> {<br> HttpApplication Application = (HttpApplication)source;<br> HttpResponse Response=Application.Context.Response;<br> Response.Write("&lt;h1&gt;Beginning of Request&lt;/h1&gt;&lt;hr&gt;");<br> }<br> private void Application_EndRequest(Object source, EventArgs e) <br> {<br> HttpApplication application = (HttpApplication)source;<br> HttpResponse Response=Application.Context.Response;<br> Response.Write("&lt;h1&gt;End of Request&lt;/h1&gt;&lt;hr&gt;");<br> } <br> public void Dispose() <br> {<br> }<br> }<br> }</ccid_code></pre> </td> </tr></table></ccid_nobr>

程序的开始引用了如下名称空间:

<ccid_nobr><table bordercolordark="#ffffff" bordercolorlight="black" width="550" align="center" border="1" cellpadding="2" cellspacing="0"><tr> <td bgcolor="#e6e6e6"> <pre><ccid_code>using System;<br> using System.Web;</ccid_code></pre> </td> </tr></table></ccid_nobr>

因为HttpApplication、HttpContext、HttpResponse等类在System.Web中定义,因此,System.Web名称空间是必须引用的。

MyModule类实现了IhttpModule接口。在Init方法中,指明了实现BeginRequest 和EndRequest 事件的方法。在这两个方法中,只是简单的分别打印了一些信息。

下面,在Web.config文件中注册这个类,就可以使用这个HttpModule了,注册的方法如下:

<ccid_nobr><table bordercolordark="#ffffff" bordercolorlight="black" width="550" align="center" border="1" cellpadding="2" cellspacing="0"><tr> <td bgcolor="#e6e6e6"> <pre><ccid_code>&lt;configuration&gt;<br> &lt;system.web&gt;<br> &lt;httpModules&gt;<br> &lt;add name=" MyModule " type=" MyModule, MyModule" /&gt; <br> &lt;/httpModules&gt;<br> &lt;/system.web&gt;<br> &lt;/configuration&gt;</ccid_code></pre> </td> </tr></table></ccid_nobr>

现在来看一下效果。编写一个Aspx页面test.aspx,内容如下:

<ccid_nobr><table bordercolordark="#ffffff" bordercolorlight="black" width="550" align="center" border="1" cellpadding="2" cellspacing="0"><tr> <td bgcolor="#e6e6e6"> <pre><ccid_code>&lt;%<br> Response.Write("&lt;h1&gt;This is the Page&lt;/h1&gt;&lt;hr&gt;");<br> %&gt;</ccid_code></pre> </td> </tr></table></ccid_nobr>

运行以后的界面如图所示:



深入研究HttpModule

HttpModule通过对HttpApplication对象的一系列事件的处理来对HTTP处理管道施加影响,这些事件在HttpModule的Init方法中进行注册,包括:

<ccid_nobr><table bordercolordark="#ffffff" bordercolorlight="black" width="550" align="center" border="1" cellpadding="2" cellspacing="0"><tr> <td bgcolor="#e6e6e6"> <pre><ccid_code>BeginRequest<br> AuthenticateRequest<br> AuthorizeRequest<br> ResolveRequestCache<br> AcquireRequestState<br> PreRequestHandlerExecute<br> PostRequestHandlerExecute<br> ReleaseRequestState<br> UpdateRequestCache<br> EndRequest</ccid_code></pre> </td> </tr></table></ccid_nobr>

其中部分事件同Global.asax中的事件相对应,对应关系如下:

<ccid_nobr><table width="502" border="1"> <tr> <td>HttpModule</td> <td>Global.asax</td> </tr> <tr> <td>BeginRequest</td> <td>Application_BeginRequest</td> </tr> <tr> <td>AuthenticateRequest</td> <td>Application_AuthenticateRequest</td> </tr> <tr> <td>EndRequest</td> <td>Application_EndRequest</td> </tr> </table></ccid_nobr>

在例1中,处理了BeginRequest和EndRequest事件,其他事件的处理方式基本上类似。

同HttpHandler对应来看,这些事件,有些在HttpHandler之前发生,有些在HttpHandler处理完后发生。了解事件发生的顺序非常重要,因为,服务器端的对象在不同的时间段有着不同的表现。例子之一是Session的使用。不是所有的事件中都能对Session进行处理,而只能在有限的几个事件中进行处理。详细的过程可以参考下面的HTTP Request处理生命周期图。



使用HttpModule实现权限系统

我们在开发应用系统的时候,应用系统的权限控制是非常重要的一个部分。在ASP中,要实现权限的控制是比较麻烦的事情,因为我们必须在每个需要控制权限的ASP页面中添加权限控制代码,从而控制客户对页面的访问。这样带来的问题,除了编写大量重复代码外,由于权限控制部分同业务处理部分的模块紧密耦合在一起,对权限控制模块的修改,往往又会带来大量的修改工作,甚至造成大量的Bug。

所以,我们现在需要将权限控制和业务处理模块进行解耦,使得两个部分可以独立开发和修改,而不会互相影响,或者,将影响减到最低。在Jsp程序中,这个目的可以通过引入一个前端控制器来实现权限过滤(关于前端控制器模式,可以参见《J2EE核心模式一书》)。在ASP.Net中,我们可以利用HttpModule实现同样的效果。下面来看一下实现的过程。

首先,我们会构建一个权限处理系统,可以检测某个用户对某个模块功能是否有访问权限(具体的结构,我想,读者都应该接触过这个部分的编程,所以不再赘述),其中,暴露给客户端调用的权限校验类的定义如下:

<ccid_nobr><table bordercolordark="#ffffff" bordercolorlight="black" width="550" align="center" border="1" cellpadding="2" cellspacing="0"><tr> <td bgcolor="#e6e6e6"> <pre><ccid_code>public class RightChecker<br> {<br> public static bool HasRight(User user,Module module)<br> {<br> //进行权限校验,<br> }<br> }</ccid_code></pre> </td> </tr></table></ccid_nobr>

然后,我们利用HttpModule编写一个过滤器:

<ccid_nobr><table bordercolordark="#ffffff" bordercolorlight="black" width="550" align="center" border="1" cellpadding="2" cellspacing="0"><tr> <td bgcolor="#e6e6e6"> <pre><ccid_code>using System;<br> using System.Web; <br> namespace MyModule<br> {<br> public class MyModule : IHttpModule <br> {<br> public void Init(HttpApplication application) <br> { <br> application. AcquireRequestState += (new <br> EventHandler(this.Application_AcquireRequestState));<br> }<br> private void Application_AcquireRequestState (Object source, <br> EventArgs e) <br> {<br> HttpApplication Application = (HttpApplication)source;<br> User user=Application.Context.Sesseion["User"] //获取User<br> string url=Application.Context.Request.Path; <br> //获取客户访问的页面<br> Module module= //根据url得到所在的模块<br> If(!RightChecker.HasRight(user,module))<br> Application.Context.Server.Transfer("ErrorPage.aspx"); <br> //如果没有权限,引导到错误处理的页面<br> }<br> public void Dispose() <br> {<br> }<br> }<br> }</ccid_code></pre> </td> </tr></table></ccid_nobr>

将这个类按照前面介绍的方法,在Web.Config中注册后,我们的应用系统就具备权限管理的功能了。怎么样,比原来的方式好很多吧?
分享到:
评论

相关推荐

    asp.net知识库

    从NUnit中理解.NET自定义属性的应用(转载) 如何在.NET中实现脚本引擎 (CodeDom篇) .NET的插件机制的简单实现 我对J2EE和.NET的一点理解 难分难舍的DSO(一) InternalsVisibleToAttribute,友元程序集访问属性 ...

    Url重写篇视频------本讲将通过实例比较ASP.NET下的三种典型URL重写方案

    ASP.NET2.0内置的urlMappings和基于自定义HTTPModule的URL重写(使用NBear.Web中的UrlRewriteModule实现),并探讨URL重写中可能遇到的陷阱及处理办法。 需要手动为UrlRewriteWebSite目录添加一个到...

    ASP.NET权限管理系统(FrameWork)

    ASP.NET权限管理系统(FrameWork) 1.起源 在我们开发软件过程中,经常会需要开发一个后台管理程序.用于管理我们开发的前台软件. 当你开发的软件越来越多的时候,你的管理后台也会越来越多.这时如果有一个统一的管理...

    史上最好传智播客就业班.net培训教程60G 不下会后悔

    在ASP.Net课程的一开始,不是直接教学员怎么拖ASP.Net控件进行快速开发,而是通过ashx的模式开发原始的动态网站,让学员明白“请求—处理—响应模型”、“Http协议、Http无状态”、“c#代码渲染生成浏览器端...

    北京中科信软 Visual Basic.NET培训

    四 Web应用(ASP.NET&XML; WebService ASP.NET 页面控制机制及编译模型,页面周期,常用控件,自定义控件,用户控件 MasterPage,主题与皮肤,站点导航,数据源控件,数据绑定 AJAX,数据缓存,个性化用户配置,Web...

    ASP.NET权限管理系统

    ASP.NET权限管理系统(FrameWork) 1.0.7源码 1.起源 在我们开发软件过程中,经常会需要开发一个后台管理程序.用于管理我们开发的前台软件. 当你开发的软件越来越多的时候,你的管理后台也会越来越多.这时如果有一个...

    ASP.NET通用权限管理系统(FrameWork) v1.0.9.zip

    1)其可以支持多个应用,多个模块的权限管理. 2)支持Access和MsSql200/2005及Oracle9i以上. 3)采用角色来进行权限的授权,每个用户可以属于多个角色,享有交差权限. 4)整合方便,权限检测采用httpmodule方式检测.基本...

    ASP.NET通用权限管理系统(FrameWork) v1.0.9

    进行后台权限管理模块整合.1)其可以支持多个应用,多个模块的权限管理.2)支持Access和MsSql200/2005及Oracle9i以上.3)采用角色来进行权限的授权,每个用户可以属于多个角色,享有交差权限.4)整合方便,权限检测采用...

    ASP.NET通用权限管理系统(FrameWork)

    ASP.NET权限管理系统(FrameWork) 1.0.7 Release 说明文档 1.起源 在我们开发软件过程中,经常会需要开发一个后台管理程序.用于管理我们开发的前台软件. 当你开发的软件越来越多的时候,你的管理后台也会越来越多.这时...

    asp.net(c#)开源权限管理系统

    1)其可以支持多个应用,多个模块的权限管理. 2)支持Access和MsSql200/2005及Oracle9i以上. 3)采用角色来进行权限的授权,每个用户可以属于多个角色,享有交差权限. 4)整合方便,权限检测采用httpmodule方式检测.基本不用...

    CompressionModule(自定义HttpModule)

    C# ASP.NET 服务端压缩Http请求的文件后发送给客房端, 包括JS,CSS文件。 主要三个功能: 1,压缩webpage 2,合并多个JS/CSS请求 为一个请求并压缩。 3,压缩WebResource.axd 文章地址 ...

    asp.NET权限管理系统(FrameWork) 1.0.7源码

    2)支持Access和MsSql200/2005及Oracle9i以上. 3)采用角色来进行权限的授权,每个用户可以属于多个角色,享有交差权限. 4)整合方便,权限检测采用httpmodule方式检测.基本不用对原有程序进行修改,便可将原有程序进行整合...

    Telerik.Web.UI安装包01

    r.a.d.input - 一个支持高度自定义的控件,用于控制ASP.NET程序中的数据输入. r.a.d.menu - 一个“"all-in-one”的菜单控件 r.a.d.panelbar - 一个可折叠的侧向菜单控件 r.a.d. rotator - 一个DHTML的rotator工具...

    模拟程序让你明白 WCF 运行过程

    通过一个普通的ASP.NET Web程序模拟了ASP.NET MVC的执行流程,现在我们通过类似的原理创建一个用于模拟WCF服务端和客户端工作原理的模拟程序。 一、基本的组件和执行流程 二、创建自定义HttpHandler实现对服务调用...

    仿淘宝网程序无错版

    易想多用户商城是易想网络旗下的C2C多用户网店系统,基于Asp.Net+C#+Access,具有智能化、高扩展、稳定、安全等特性,并拥有超强功能,可自由添加频道,后台智能修改风格,只要懂得网站常识的站长就可以轻松利用易想...

    百度竞价排名项目

    仿百度后台竞价排名 而做的一个项目,功能还未完全,有待继续。。 但有许多技术点学习,如httpmodule 的权限管理,自定义的分页。。。。。

    MVC源码学习:打造自己的MVC框架

    2.2、Asp.net中常见的HttpHandler类型 ...................................................................................................... 7 2.3、自定义HttpHandler。 .....................................

Global site tag (gtag.js) - Google Analytics