• mvc controller放目录里面该怎么办?


    方法一,可以在目录中命名一个和目录同样名字的controller,然后用特性来进行设置,比如:

    Controllers/myfolder/myfolderController.cs

    我建立了上述结构,注意 myfolder就是我自己建立的目录,因此控制器名字也要交myfolder。
    然后在控制器里面写:

    [HttpGet]
    [ActionName("Index")]
    public ActionResult abcd(string id){
        retrun View("~/Views/Home/About.cshtml");
    }






    Mvc多级Views目录 asp.net mvc4 路由重写及 修改view 的寻找视图的规则 一般我们在mvc开发过程中,都会碰到这样的问题。页面总是写在Views文件夹下,而且还只能一个Controller的页面只能写在相应的以Controller名命名的文件夹下。如果我们写到别处呢?那么肯定会报错。这是mvc中一个约定俗成的一个规定,必须这样写。
    1.正常的项目目录,如下图:
          

          我们要访问Index页面,只需要输入Home/Index就可以访问了。我们之所以能够这样访问,是因为我们在项目创建之初系统就默认配置了一个默认的路由。我们可以按照这个默认的路由规则进行访问。



    2.那么我们再来看我们需要的访问方式,如下图


          如果我们要访问Admin下的TestController里面的Index页面,那么我们输入Test/Index,这个肯定不行的。因为TestController根本就不在Controllers的根目录下,而是在Controllers/Admin下,这样我们根本就找不到Test这个Controller。那么我们输入Admin/Test/Index,那么我们就需要添加一个路由配置了,因为以前的默认路由只能通过{Controller}/{Action}/{Id}这种方式访问,就是必须以Controller开头。我们重新配置的路由如下:



    public static void RegisterRoutes(RouteCollection routes)
             {
                 routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
                 
                 //路由规则匹配是从上到下的,优先匹配的路由一定要写在最上面。因为路由匹配成功以后,他不会继续匹配下去。
                 routes.MapRoute(
                    "Admin", // 路由名称,这个只要保证在路由集合中唯一即可
                    "Admin/{controller}/{action}/{id}", //路由规则,匹配以Admin开头的url
                    new { controller = "Home", action = "Index", id = UrlParameter.Optional } // 
                );

                 routes.MapRoute(
                     "Default", // Route name
                     "{controller}/{action}/{id}", // URL with parameters
                     new { controller = "Home", action = "Index", id = UrlParameter.Optional } // Parameter defaults
                 );

         }
    View Code  那么我们这个时候再次输入Admin/Test/Index,能找到Views/Admin/Test/Index.cshtml这个页面吗?显然是不能的,因为除了路由配置怎么访问Controller外,寻找Views里面的页面也有自己的规则。测试结果肯定是找不到页面,我们看看错误信息就知道他是怎么寻找cshtml页面了。

        

        

    “The following locations were searched” 翻译过来就是"以下地址被搜索过"。那么他只搜索这些地址,这里我只写razor视图的地址,写成通配符就是:
    •Views/{1}/{0}.cshtml
    •Views/Shared/{0}.cshtml
    {1}表示Controller的名称,{0}表示视图名称,Shared是存放模板页的文件夹。一看就很清楚了。这个就是寻找视图的规则,所以我们存放在Admin/Test/Index.cshtml的存放规则就不满足。那么我们修改下,如下图:



      直接将Test文件夹存放在Views下面,那么我们就满足这个寻找视图的规则了,我们输入Admin/Test/Index,也确实访问成功了。

        

    但是这个方式的存储肯定不是我们需要的,既然我们Controller区分存放了,我们肯定也希望Views也能够这样存放的。

    3.那么我们进入正题,修改他的寻找视图的规则,让他能够按照我们的规则来访问,就像修改路由一样。
    在项目中新建立一个cs类MyViewEngine,继承RazorViewEngine。代码如下:



    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Mvc;
    namespace MvcRoute.MvcEx
    {

        public sealed class MyViewEngine : RazorViewEngine
        {

            public MyViewEngine()
            {
                ViewLocationFormats = new[]
                {
                    "~/Views/{1}/{0}.cshtml",
                    "~/Views/Shared/{0}.cshtml",
                    "~/Views/Admin/{1}/{0}.cshtml"//我们的规则
                };
            }
            public override ViewEngineResult FindView(ControllerContext controllerContext, string viewName, string masterName, bool useCache)
            {
                return base.FindView(controllerContext, viewName, masterName, useCache);
            }

        }
    }
    View Code 然后将这个规则注册到系统中,在global中注册一下,这样我们就可以通过自己的方式来访问了。global注册如下:



    protected void Application_Start()
            {
                AreaRegistration.RegisterAllAreas();

                RegisterGlobalFilters(GlobalFilters.Filters);
                RegisterRoutes(RouteTable.Routes);

                RegisterView();//注册视图访问规则
            }

            protected void RegisterView()
            {
                ViewEngines.Engines.Clear();
                ViewEngines.Engines.Add(new MyViewEngine());
            }
    View Code  结果如下图:

        





  • 相关阅读:
    java数据库连接池
    ThreadLocal遇到线程池时, 各线程间的数据会互相干扰, 串来串去
    当ThreadLocal碰上线程池
    threadLocal遇上线程池导致局部变量变化
    java自带线程池和队列详细讲解
    Java 多线程下的单例模式
    一个错误使用单例模式的场景及ThreadLocal简析
    总结SQL Server窗口函数的简单使用
    sqlserver中drop、truncate和delete语句的用法
    JBOSS连接池默认连接数是多少?在哪个配置文件有这个默认的连接数?
  • 原文地址:https://www.cnblogs.com/qinge/p/5329479.html
Copyright © 2020-2023  润新知