zoukankan      html  css  js  c++  java
  • MVC_Route层层深入

    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

  • 相关阅读:
    天平天国和诗,和远方,和苟且
    ui设计师做好这几点,产品经理准闭嘴
    谈谈个人视觉创意的学习经验
    保持觉知
    第37周本人进步点
    扒一扒万恶的导航网站
    16年第四本《简单的逻辑学》
    hey,开通个人公众号啦!
    今朝有酒今朝醉,也是一种理性-附个人心得
    元素的定位
  • 原文地址:https://www.cnblogs.com/wskxy/p/9217057.html
Copyright © 2011-2022 走看看