也说UrlRewriter

本文介绍了一种适用于ASP.NET 1.1的URL重写技术实现,主要包括定义重写规则、转换友好URL至实际URL及解决表单Action路径问题。通过自定义重写规则和利用HttpContext.Current.RewritePath方法,实现了URL的友好展示。
UrlRewriter是我们现在做博客系统基本上必用的功能,除了对搜索引擎友好外,人也比较容易记,看着也舒服。关于UrlRewriter的文章其实也是非常多,由于有网友提出想了解 肥猫博客使用的UrlRewriter技术,因此这里主要针对在 肥猫博客中使用的UrlRewriter技术做一个介绍。这个实现主要是针对ASP.NET 1.1体系的,可能你要说ASP.NET 2.0都出来了,还要谈1.1,可是我一直用的是1.1,也没有接触过2.0,所以针对ASP.NET 2.0的UrlRewriter技术不在这里阐述。
 
UrlRewriter有多种实现方式,常用的有:HttpModule,HttpHandler和Application_BeginRequest方式处理。对于前2种,现在都有很成熟的解决方法,比较有名的就是 UrlRewriter.NET,我建议你如果要用到UrlRewriter首先就应该优先考虑这种成熟的解决方案。UrlRewriter.NET在这里不作介绍。
在肥猫博客中,我使用的是Global.ascx文件中的Application_BeginRequest方式。对于这种方式,我们需要做3个工作:
1.         定义UrlRewriter的重写方式,一般这可以是一个xml文件来定义你需要用到的所有重写URL。
该文件的内容大致如下:
<? xml version ="1.0" encoding ="utf-8" ?>
< pages >
    <pagename=""url="^/admin(.*)$"rewriter="/admin$1"/>
    <pagename=""url="^/control(.*)$"rewriter="/control$1"/>
 
    <pagename=""url="^/([A-Za-z0-9]+)/default/.aspx$"rewriter="/default.aspx?m=$1"/>
    <pagename="BlogHome"url="^/([A-Za-z0-9]+)/blog/default/.aspx$"rewriter="/blog/default.aspx?m=$1"/>
</ pages >
       这个文件中最主要的定义是url和rewriter,其他的都是程序中辅助用到的字段。url定义的是友好的地址,比如: http://www.fmblog.cn/jasper/feed/default.aspx,而rewriter定义的则是根据这个友好地址如何生成对应的实际地址,比如上面那个友好地址对应的实际地址为: http://www.fmblog.cn/feed/default.aspx?m=jasper
       所有系统中用到的重写url都必须实现定义好,而且我建议用到正则表达式来定义。
2.       使用HttpContext.Current.RewritePath(url)方法来将友好地址变成实际地址
有了上面第一步的url定义,接着就在Global.ascx的Application_BeginRequest方法中将友好地址转变为实际地址。
            foreach(fmblog.Data.Config.UrlRule item in fmblog.Data.Config.Url.Rules)
            {
                Regex regex = new Regex(item.Url, RegexOptions.IgnoreCase);
 
                if(regex.IsMatch(Request.RawUrl))
                {
                    string url = regex.Replace(Request.RawUrl, item.Rewriter);
 
                    HttpContext.Current.RewritePath(url);
                   
                    return;
                }
            }
这个方法很简单,fmblog.Data.Config.Url.Rules读取的就是第1步中的所有url重写规则,我们看这个方法就是很简单的把实际地址得到后,进行了一个RewritePath操作,这样就完成了我们需要的重写功能。不过,这会带来一个小问题。
3.         带来的小问题就是所有HtmlForm的Action都是实际地址,而不是友好地址
为了解决这个HtmlForm的Action问题,我们需要自己写一个MyForm从HtmlForm继承过来,并且在输出的时候,将action改成我们需要的实际地址。这个我们通过重载MyForm的RenderAttributes方法实现,如下所示:
        protected override void RenderAttributes(System.Web.UI.HtmlTextWriter writer)
        {
            writer.WriteAttribute("name", this.Name);
            base.Attributes.Remove("name");
 
            writer.WriteAttribute("method", this.Method);
            base.Attributes.Remove("method");
 
            this.Attributes.Render(writer);
 
            writer.WriteAttribute("action", this.Page.Request.RawUrl);
            base.Attributes.Remove("action");
 
            if (base.ID != null)
            {
                writer.WriteAttribute("id", base.ClientID);
            }
        }
 
然后将页面上用到的Form都改成这个MyForm就好了。
 
这种实现方式,还有1个小问题,就是登陆转向的问题。如果你没有登陆,但是访问了一个需要登陆认证的页面,在ASP.NET中会自动将你导航到登陆页面,并且在登陆后会重定向到需要访问的页面。
 
如果你的后台页面也用到了UrlRewriter,那么转向登陆页面后,其Url就会变成实际地址。如果要解决这个问题,请采用其他的方法,比如UrlRewriter.NET。在 肥猫博客中,后台页面都是使用的实际页面,所以为了控制代码我们采用了这种自己写代码的简单处理方式。
其实,UrlRewriter现在是一个很成熟的东西,网上有很多内容肯定能够符合你的需求,这里只是简单的介绍一个可行的方案,还有其他很多成熟方案可以采用,所以在使用UrlRewriter之前,先在网上找些资料好对症下药。
不管怎样,最简单的还是直接使用成熟的UrlRewriter控件。
 
基于径向基函数神经网络RBFNN的自适应滑模控制学习(Matlab代码实现)内容概要:本文介绍了基于径向基函数神经网络(RBFNN)的自适应滑模控制方法,并提供了相应的Matlab代码实现。该方法结合了RBF神经网络的非线性逼近能力和滑模控制的强鲁棒性,用于解决复杂系统的控制问题,尤其适用于存在不确定性和外部干扰的动态系统。文中详细阐述了控制算法的设计思路、RBFNN的结构与权重更新机制、滑模面的构建以及自适应律的推导过程,并通过Matlab仿真验证了所提方法的有效性和稳定性。此外,文档还列举了大量相关的科研方向和技术应用,涵盖智能优化算法、机器学习、电力系统、路径规划等多个领域,展示了该技术的广泛应用前景。; 适合人群:具备一定自动控制理论基础和Matlab编程能力的研究生、科研人员及工程技术人员,特别是从事智能控制、非线性系统控制及相关领域的研究人员; 使用场景及目标:①学习和掌握RBF神经网络与滑模控制相结合的自适应控制策略设计方法;②应用于电机控制、机器人轨迹跟踪、电力电子系统等存在模型不确定性或外界扰动的实际控制系统中,提升控制精度与鲁棒性; 阅读建议:建议读者结合提供的Matlab代码进行仿真实践,深入理解算法实现细节,同时可参考文中提及的相关技术方向拓展研究思路,注重理论分析与仿真验证相结合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值