ASP.NET中URL Routing和IIS上URL Rewriting的区别

前面有2篇帖子提到了关于URL Routing的特性,但是发现有很多人误会URL Routing就是URl Rewriting,其实2个虽然都提供相似的功能(提高友好的URL方便搜索引起收录),但是2者的原理和运行周期是完全不一样的,本篇文章我们就来分析一下具体有什么不同。

例子

在分析原理之前,我们先来做一个例子测试一下(IIS URL Rewrite模块需要IIS7的支持)。

1.为Customer/1的URL建立对应的MVC程序

首先建立一个普通的MVC3程序,建立一个简单的CustomerController以及一个简单的Detail action,代码如下:

public class CustomerController : Controller { public ActionResult Detail(string id) { ViewBag.CustomerID = id; return View(); } }

我们只是简单的接受一个ID,然后放到ViewBag里以便在view里显示,view的代码如下:

@{ Layout = null; } <!DOCTYPE html> <html> <head> <title>Detail</title> </head> <body> <div> MVC下运行结果:@ViewBag.CustomerID </div> </body> </html>

2.为Customer/1的URL建立对应的web form程序

在同一个解决方案的根目录下,建立一个Customer.aspx文件,文件代码主要是接受一个ID参数然后显示在页面上,代码:

public partial class Customer : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { this.lblId.InnerText = Request.QueryString["id"]; } }

html:

<form runat="server"> <div> asp.net web form下是:<label runat="server"></label> </div> </form>

OK,我们先在Global.asax.cs里配置Customre/1的route,代码如下:

routes.MapRoute( "CustomerDetail", // Route name "Customer/{id}", // URL with parameters new { controller = "Customer", action = "Detail", id = UrlParameter.Optional } );

编译访问,运行,页面显示结果是:

MVC下运行结果:123。

3.安装IIS URL Rewrite

到如下地址下载并安装IIS URL Rewrite, 成功安装以后,在MVC项目的web.config里配置一条URL重写规则,代码如下(注意是system.webServer节点哦):

<system.webServer> <validation validateIntegratedModeConfiguration="false"/> <modules runAllManagedModulesForAllRequests="true"/> <directoryBrowse enabled="true" /> <rewrite> <rules> <rule> <match url="^customer/([0-9]+)" /> <action type="Rewrite" url="customer.aspx?id={R:1}" /> </rule> </rules> </rewrite> </system.webServer>

该规则的意思是,将customer/1类似的请求重写到customer.aspx?id=1上,我们编译程序再来访问以下,页面显示结果如下:
asp.net web form下是:123

也就是说Routing在这个时候没起作用,因为URL Rewrite是在Routing之前将Customer/123这个地址转发到了Customer.aspx?id=123,由aspx文件接收请求了。我们来看看2者之间到底都是在什么周期处理的。
原理周期

1. URL Rewrite

关于URL Rewrite最早见于apache web server,当时风靡一时的url重写让一大批使用php的人欣喜若狂啊,可惜之前由于asp.net下的实现方式特别复杂,所以很多站的基本上都没怎么用,自从IIS.net推出正式的IIS URL Rewrite模块以来,彻底解决了这一问题。

URL Rewrite是在request-processing pipeline的早期阶段执行的,一般一个地址进来以后,该模块会根据规则来映射到同一服务器上的另外一条新的地址,新地址在处理的时候所接受的参数和数据都是一句新地址的参数来判断的,就比如customer.aspx?id=123,而 request里的url也是新的地址,而不是重写之前的地址,不过用户本身感觉不到变化,因为浏览器上显示的一直是旧URL,我们来看一下他的周期图。

/uploads/allimg/200612/164US0H_0.gif

URL Rewrite module是一个native的模块,从图可以看到他的运行周期是在Pre-begin Rquest和Begin Request之间,该模块在根据请求的URL进行规则匹配之后,最终处理新的URL以便进入IIS pipeline的剩余周期里进行处理,就是说处理请求的HttpHandler是根据重写以后的新URL来决定的。

2. URL Routing

URL Routing的原理是根据现有的URL来定义规则,定义每个规则所对应的HttpHandler,其本质和URL是否友好没有关系,只是按照统一的规则去调用相对应的HttpHandler而已,找到对应的HttpHandler,处理完以后就返回结果,找不到就暴资源错误。

/uploads/allimg/200612/164U951a_0.gif

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wjyxfz.html