1.前期准备
新建一个MVC项目,并添加Home和About两个控制器
在这两个控制器对应添加index页面
namespace Study_MVC_Route.Controllers { public class HomeController : Controller { // GET: Home public ActionResult Index() { return View(); } public string Regex(int year,int month,int day) { return $"{year}-{month}-{day}";
//$是在字符串中内嵌参数 } } }
namespace Study_MVC_Route.Controllers { public class AboutController : Controller { // GET: About public ActionResult Index() { return View(); } } }
2.添加路由
在APP_Start文件夹下面的RouteConfig.cs,是MVC的路由配置文件
主要属性如下:
name: 路由名称 url: 和url匹配的正则表达式,用{}表示一个参数变量,可以为空;无{}则是一个硬性的匹配要求 defaults: 默认,匹配上url后,若url参数为空,则使用默认动作 controller = 默认控制器, action = 默认动作, id = 参数
constraints: url参数约束
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; using System.Web.Routing; namespace Study_MVC_Route { public class RouteConfig { public static void RegisterRoutes(RouteCollection routes)//路由集,由上往下匹配路由 { routes.IgnoreRoute("{resource}.axd/{*pathInfo}");//忽略路由
//--------------------------------添加路由------------------------------------------ //以Test开始的url
//url没有引入controller参数,所以controller使用默认值,若不给参数赋值,也使用默认值
routes.MapRoute( name: "Test", url: "Test/{action}/{id}", defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional } );
//Route的书写可以省略命名参数,即name、url、defaults这些命名参数可以省略,如下 //url为About可以访问Home/Index routes.MapRoute("About1", "About", new { controller = "Home", action = "Index", id = UrlParameter.Optional }); //url为About访问About/Index routes.MapRoute("About2", "{controller}", new { controller = "Home", action = "Index", id = UrlParameter.Optional });
//加大括号表示参数,不加则为一个普通字符串链接,是一个硬性的匹配要求
//传参对比 //使用constraints做参数约束 //home/Regex_2014_05_19 routes.MapRoute( name: "Regex", url: "{controller}/{action}_{year}_{month}_{day}", defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }, constraints: new { year = @"d{4}", month = @"d{2}", day = @"d{2}" }// @"d{4}"表示输入四位数字,@表取消的转译效果 ); //普通传参 //home/Regex?year=2014&month=05&day=19 routes.MapRoute( name: "Default", url: "{controller}/{action}/{id}", defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional } ); } } }
3.扩展
使用一个路由扩展类对浏览器进行判断
public class AgentRoute : RouteBase { public override RouteData GetRouteData(HttpContextBase httpContext) { if(httpContext.Request.UserAgent.IndexOf("Edge/12.10240") >-1)//判断是否使用了Edge浏览器 { RouteData routeData = new RouteData(this,new MvcRouteHandler()); routeData.Values.Add("controller", "Edge"); routeData.Values.Add("action", "Index"); return routeData; } else { return null; } } public override VirtualPathData GetVirtualPath(RequestContext requestContext, RouteValueDictionary values) { return null; } }
在RouteConfig中添加这个类的实例(也就是添加一个路由规则)
routes.Add(new AgentRoute());//这行代码放在不同的路由下面有不同的效果
比如:
1、放在最前面
这样在进行其他路由判断之前,会先进行这个判断,即每次访问url都会先判断是否是Edge浏览器
若是,命中路由
若不是,return null ;继续往下判断
2、要是将其放在路由Test后面
那Edge也可以访问 Test/{action}/{id} 这个规则的url,因为这个路由规则会先被命中
效果展示:
Chrome浏览器,正常访问
Edge浏览器,会访问Edge/Index页面,因为它命中了AgentRoute