介绍
System.Web.Routing - 此命名空间提供用于 URL 路由的类,通过该类可以使用不映射到物理文件的 URL
- IRouteHandler - 路由处理程序接口,自定义的路由处理程序都要实现这个接口
- RequestContext - 封装所请求的路由的相关信息和当前的 http 上下文信息
- RouteData - 所请求的路由的相关信息
- RouteCollection - 路由集合
- RouteValueDictionary - 不区分大小写的 key/value 字典表
- Route - 路由的相关信息
示例
1、MyHandler.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
using System.Web.Routing;
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
namespace MVC.RoutingDemo
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 路由处理程序
/// </summary>
public class MyRouteHandler : IRouteHandler
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//*
* IRouteHandler - 路由处理程序接口,自定义的路由处理程序都要实现这个接口
* 该接口有一个方法 IHttpHandler GetHttpHandler(RequestContext requestContext)
* 此方法需要返回一个处理该路由的 http 处理程序 (HttpHandler)
* RequestContext - 封装所请求的路由的相关信息和当前的 http 上下文信息
* RequestContext.HttpContext - 当前的 http 上下文信息
* RequestContext.RouteData - 所请求的路由的相关信息
*/
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public IHttpHandler GetHttpHandler(RequestContext requestContext)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
return new MyHttpHandler(requestContext);
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 自定义的 http 处理程序,由路由决定使用哪个 http 处理程序
/// </summary>
public class MyHttpHandler : IHttpHandler
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
public RequestContext RequestContext
{ get; private set; }
public MyHttpHandler(RequestContext context)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
RequestContext = context;
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public void ProcessRequest(HttpContext httpContext)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//*
* RouteData - 所请求的路由的相关信息
* RouteData.Values - 一个字典表(key - 路由参数;value - 路由值)
* RouteData.DataTokens - 自定义需要传递的数据,也是一个字典表
* RouteData.GetRequiredString(string key) - 获取指定的路由参数所对应的路由值
*/
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
httpContext.Response.Write("相关参数为:<br />");
foreach (var dic in RequestContext.RouteData.Values)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
httpContext.Response.Write(dic.Key + " : " + dic.Value + "<br />");
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
httpContext.Response.Write("相关Token为:<br />");
foreach (var dic in RequestContext.RouteData.DataTokens)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
httpContext.Response.Write(dic.Key + " : " + dic.Value + "<br />");
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public bool IsReusable
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
get
{ return false; }
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 如果有 n 多的路由处理程序,为了方便调用,减少代码,我们可以将其写成一个 Factory 类,如下:
/// </summary>
public class RouteHandlerFactory : IRouteHandler
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
private string _name;
public RouteHandlerFactory(string name)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
_name = name;
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public IHttpHandler GetHttpHandler(RequestContext requestContext)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
if (_name == "My")
return new MyHttpHandler(requestContext);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
return new MyHttpHandler(requestContext);
}
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//// <summary>
/// 演示不经过路由,根据 web.config 中的 HttpHandler 相关配置,由此 HttpHandler 直接处理相关请球。具体配置见 Global.asax
/// </summary>
public class XXXHttpHandler : IHttpHandler
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
public XXXHttpHandler()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public void ProcessRequest(HttpContext context)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
context.Response.Write(context.Request.Url.ToString());
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public bool IsReusable
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
get
{ return false; }
}
}
}2、
Web.config
<?xml version="1.0"?>
<configuration>
<system.web>
<httpHandlers>
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
<!--
配置一个自定义的 HttpHandler,用于处理后缀名为 xxx 的页面
如果不需要将 *.xxx 交给路由处理,而是直接让指定的 HttpHandler 处理,请参看 Global.asax 中的配置
-->
<add verb="*" path="*.xxx" type="MVC.RoutingDemo.XXXHttpHandler" />
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
</httpHandlers>
<httpModules>
<!--
UrlRoutingModule - 用于匹配 asp.net 应用程序中的路由的 http 请求
该模块找到匹配路由后,会检索 IRouteHandler 对象,以查找该路由,然后从该路由处理程序获取一个 IHttpHandler 对象,并将该对象用作当前请求的 http 处理程序
-->
<add name="UrlRoutingModule" type="System.Web.Routing.UrlRoutingModule, System.Web.Routing, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>
</httpModules>
</system.web>
</configuration>
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
3、Global.asax.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Routing;
data:image/s3,"s3://crabby-images/e95e4/e95e42cc52c789b51b547627ca6c799739e0b9b5" alt=""
namespace MVC
data:image/s3,"s3://crabby-images/9ed40/9ed401c13ef0ca53ee83c3ffe3144daad9d9621b" alt=""
data:image/s3,"s3://crabby-images/849a8/849a86ef3296874633785479796ce82040871888" alt=""
{
// Note: For instructions on enabling IIS6 or IIS7 classic mode,
// visit http://go.microsoft.com/?LinkId=9394801
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
public class MvcApplication : System.Web.HttpApplication
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
public static void RegisterRoutes(RouteCollection routes)
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//* 路由方向:自上而下,查找到匹配的就去处理,而不会继续往下做匹配 */
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//*
* RouteCollection - 路由集合
* RouteCollection.IgnoreRoute() - 指定的地址不由路由处理
* RouteCollection.Add() - 新增一个路由配置
* RouteCollection.MapRoute() - 映射一个路由(Add() 方法的简化版,内部会自动调用 MvcRouteHandler)
*/
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// .asd 文件不走此路由
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
// .xxx 文件不走此路由
routes.Add(new Route("{resource}.xxx/{*pathInfo}", new StopRoutingHandler()));
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
/**//*
* RouteValueDictionary - 不区分大小写的 key/value 字典表
* Route - 路由的相关信息
* Route.Url - 路由的 url 匹配模式,{ } 内的为需要匹配的路由参数名
* Route.Defaults - 路由参数的默认值
* Route.RouteHandler - 路由对应的路由处理程序
* Route.DataTokens - 自定义需要传递的数据
* Route.Constraints - 约束参数值的有效性(可以是正则表达式(不区分大小写),也可以是实现了 IRouteConstraint 的对象)
*/
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
Route route = new Route(
"Routing/{parent}/{child}",
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// RouteValueDictionary - 可以接收一个匿名对象为参数,属性名转换为 key, 属性值转换为 value
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new RouteValueDictionary(new
{ parent = "ria", child = "silverlight", controller = "Product", action = "Index" }),
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
new RoutingDemo.MyRouteHandler()
);
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
route.DataTokens = new RouteValueDictionary(new
{ token1 = "abc", token2 = "xyz" });
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// HttpMethodConstraint - 实现了 IRouteConstraint 接口的类,用于约束 http 方法
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
route.Constraints = new RouteValueDictionary(new
{ parent = @"^[a-zA-Z]+$", httpMethod = new HttpMethodConstraint("GET") });
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// 将路由添加进路由集合,名称可以随便设置,但必须唯一(也可以不设置路由名称)
routes.Add("MyRoutingDemo", route);
// routes.Add(route);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// * - 路由也支持通配符
// {*param} - 代表匹配任意值,其中路由参数名为 param
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
routes.Add(new Route("Wildcard/{*param}", new RouteValueDictionary(new
{ controller = "Product", action = "Index" }), new RoutingDemo.MyRouteHandler()));
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// MapRoute() 封装了 Add(), MapRoute() 内部会自动调用 MvcRouteHandler
// 其中必须要有 controller 项和 action 项
// 其中设置 namespaces 参数相当于 route.DataTokens["Namespaces"] = namespaces;
routes.MapRoute(
"Products",
"ProductList/{pageIndex}",
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new
{ controller = "Product", action = "Index", pageIndex = 0 }
);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
new
{ controller = "Home", action = "Index", id = "" } // Parameter defaults
);
}
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
protected void Application_Start()
data:image/s3,"s3://crabby-images/36973/3697370d352d639f06fcffe6068238bbf4bf9202" alt=""
{
RegisterRoutes(RouteTable.Routes);
data:image/s3,"s3://crabby-images/0da99/0da994ad2b837f05c4855bad3b115a255fbd7473" alt=""
// 调试路由(需要 RouteDebug.dll),调用如下语句后,会在每个页面都显示详细的路由信息
// RouteDebug.RouteDebugger.RewriteRoutesForTesting(RouteTable.Routes);
}
}
}