asp.net利用自定义Http处理程序实现URL伪静态之初探

之前在做过的一个项目中,也实现了伪静态URL页面的办法,不过那是利用URLRewriter.dll并需要通过配置IIS才得以实现,而且通过这个方法实现还有不少要求,但在实际过程中,服务器我们是买别人家公司的,并不能实现登录虚拟机进行配置IIS,甚至如果服务器供应商都不提供有支持.framework 4.0,那这实现又从何说起?!


    近日看了一些HTTP管道的文章,看了上面的例子,突然想到,既然asp.net请求是通过Http管道来处理的,那为何不用它来实现伪静态化呢?于是就动手写了一个例子,发现结果还是可以的,所以拿出来分享一下:


    实现自定义的Http管道处理程序我们需要自己定义一个继承IHttpHandler接口的类,主要实现一个方法跟一个属性,例如,我定义了一个Redir类:


[csharp]  view plain  copy
  1. <pre name="code" class="csharp">public class Redir :IHttpHandler  
  2.     {  
  3.         /// <summary>  
  4.         /// 当有重复的请求时,是否重用这个资源对象  
  5.         /// </summary>  
  6.         public bool IsReusable  
  7.         {  
  8.             get  
  9.             {  
  10.                 return true;  
  11.             }  
  12.         }  
  13.   
  14.         /// <summary>  
  15.         /// 请求进程处理  
  16.         /// </summary>  
  17.         /// <param name="context"></param>  
  18.         public void ProcessRequest( HttpContext context )  
  19.         {  
  20.             string RawUrl = context.Request.RawUrl; //获取当前请求原始URL  
  21.   
  22.             //因为后缀为.html或是.shtml和.htm,我们需要进行截取并根据'-'进行分段,以便获得参数值  
  23.             string[] Paras = RawUrl.Substring( 0, RawUrl.IndexOf( '.' ) ).Split( new char[] { '-''/' }, StringSplitOptions.RemoveEmptyEntries );  
  24.             string RebulidParas = "";  
  25.   
  26.             //根据获得参数的数量进行相应的处理  
  27.             switch ( Paras.Length )  
  28.             {  
  29.                 case 2:  
  30.                     RebulidParas = "?name=" + Paras[1];  
  31.                     break;  
  32.                 case 3:  
  33.                     RebulidParas = "?name=" + Paras[1] + "&id=" + Paras[2];  
  34.                     break;  
  35.                 default:  
  36.                     break;  
  37.             }  
  38.   
  39.             //然后在服务器内部进行重新发送这个转化过的url,注意后缀恢复成了原来的.aspx,  
  40.             context.Server.Transfer( Paras[0] +".aspx" + RebulidParas  );  
  41.         }  
  42.     }  


 
     

然后在Web.Config文件中进行注册这个HttpHandler

[html]  view plain  copy
  1. <system.web>  
  2.     <httpHandlers>  
  3.         <add verb="*" path="*.shtml" type="空间名.类名,程序集名"/>  
  4.     </httpHandlers>  
  5. </system.web>   


这个类其实处理过程很简单:

    就是当有一个后缀不为.aspx的请求发送到这个HttpHandler后,假设有一个请求如下:http://www.***.com/Article-dpan-20.shtml

    这个请求发送过来,能过上下文对象中的Request.RawUrl我们可以得到一个原始请求:/Article-dpan-20.shtml

    后缀部份,我们不要,进行截尾处理变成/Article-dpan-20。然后我们需要做的就是根据'-'分隔的参数值获取出来,所以通过String.Split方法,分割成了:

(1)/Article

(2)dpan

(3)20

   剩下的工作就好做了,重新进行拼接起来就行了,所以变成了,/Article.aspx?name=dpan&id=20。通过内部转移Transfer方法将这个URL发送给对应的指定页面就OK了。


   这种重写的方法显然没有那种 /Article/dpan/20.html 这种形式来得优雅,我也尝试着进行转化处理,发现有几个问题没办法处理:

   (1)因为网站后台使用的是在线的HTML编辑器,这种编辑器会有自带的生成的.html页面,如果后缀使用了.html来进行伪静态,导致后台HTML编辑器无法正常使用。

   (2)在注册httpHandlers中的path属性,并不能认可像 /Article/*/*.shtml 这种形式的路径请求,个人猜测是在WindowForm开发下,文件映射的问题吧,具体的还没有仔细研究过,也对Web.Config研究不深,还需仔细去找资料查看看。

   

    目前通过这种形式来实现伪静态化也算是能满足一些需求吧,因为之前的网站,要不是客户自己买有云服务器,可以登录上去进行配置IIS,我都不知道如何在我们自己服务器供应商提供的只支持.framework 3.5而且也不准配置IIS这种情况下实现伪静态化了,现在通过这个自定义的扩展Http程序,也算是可以做到了。

    

   但我有找到很多人介绍说通过HttpModules截获Http请求进行处理,而且HttpModules是可以调用好几个的的,而HttpHandles只能调用一个。具体的还没有去研究过,接下来又有得忙啦!




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值