当前位置: 首页 > news >正文

asp.net core mvc之路由

一、默认路由 (Startup.cs文件)

routes.MapRoute(name: "default",template: "{controller=Home}/{action=Index}/{id?}"
);

默认访问可以匹配到
https://localhost:44302/home/index/1
https://localhost:44302/home/index
https://localhost:44302/home
https://localhost:44302

也可以匹配到
https://localhost:44302/course/learn/1

1、创建 course 控制器

Controllers文件夹下右键-,添加控制器->

-》CourseController.cs

->

2、创建learn视图

在Views文件夹下,新建 Course 文件夹,然后右键 。 添加-》视图-》learn.cshtml

@{ViewData["Title"]= "学习";
}<h1>学习页面内容</h1>

二、案例博客路由

1、在 Startup.cs 文件下配置博客路由

//防止输入https://localhost:44302/home跳到博客专用路由
routes.MapRoute(name: "home",template: "home", //https://localhost:44302/home,跳到Home控制器中Index方法defaults: new { controller = "Home", action = "Index" });//博客专用路由
routes.MapRoute(name:"blog",template:"{name}", //https://localhost:44302/博客名,跳到Blog控制器中Index方法defaults: new { controller ="Blog",action="Index"});

2、Controllers文件夹右键,添加-》控制器 BlogController.cs

    public class BlogController : Controller{public IActionResult Index(string name){ViewData["BlogName"] = name;return View();}}

3.Views文件夹下添加Blog文件夹右键,添加-》视图 Index.cshtml

<h1>@ViewData["BlogName"]博客</h1>

三、特性路由

特性路由:在Action添加标注,来指定路由规则

1、Startup.cs 文件中 app.UseMvc(删除全部路由);

2、在Action添加标注

public class HomeController : Controller
{[Route("")][Route("home")][Route("home/index")]public IActionResult Index(){return View();}[Route("home/abc")]//https://localhost:44302/home/abcpublic IActionResult About(){ViewData["Message"] = "Your application description page.";return View();}
}

注意:

A、如果2个方法有相同标注,为防止冲突,可以这样做

[HttpPost("home/abc")]

B、特性路由参数

//学习
[Route("course/learn/{id}")] //https://localhost:44302/course/learn/1
public IActionResult learn(int id)
{return View();
}

四、组合路由

组合路由:在 Controller 和Action 上添加路由标注

//课程
[Route("c")]
public class CourseController : Controller
{[Route("index")] //    https://localhost:44302/c/index[Route("/idd")] // 以/开头的不是组合路由  https://localhost:44302/iddpublic IActionResult Index(){return View();}
}

五、路由模板中使用标记替换


在路由模板中使用
[controller] 表示和控制器同名的名称
[action] 表示和Action同名的名称
[area] 表示和区域同名的名称

[Route("[controller]")]
public class CourseController : Controller
{[Route("[action]")]  // https://localhost:44302/course/indexpublic IActionResult Index(){return View();}
}

还可以在控制器上面使用多个路由特性,实现多个地址匹配一个控制器

[Route("[controller]")]
[Route("more")]  // https://localhost:44302/more/index
public class CourseController : Controller
{[Route("[action]")]  // https://localhost:44302/course/indexpublic IActionResult Index(){return View();}
}

还可以这样写

[Route("[controller]/[action]")] //https://localhost:44302/course/index
//也可以放到方法上
public class CourseController : Controller
{public IActionResult Index(){return View();}
}

六、自定义路由特性

通过创建一个实现了IRouteTemplateProvider的类。然后在类里面配置Template和Order还有Name这三个属性就可以实现特性标注了。

只要那个类或者Action增加了这个自定义标注就可以自动设置上面的Template特性。

1、在项目下添加 core 文件夹,然后添加 MyRouteAttribute.cs 类,实现 IRouteTemplateProvider

namespace FirstCoreMvc.core
{public class MyRouteAttribute : Attribute, IRouteTemplateProvider{public string Template => "www/[controller]/[action]";public int? Order {get;set;}public string Name { get; set; }}
}

2、调用

    public class BlogController : Controller{[MyRoute] //https://localhost:44302/www/blog/indexpublic IActionResult Index(string name){ViewData["BlogName"] = name;return View();}}

七、生成Url

生成url,实际应用在视图中生成链接的地址

public IActionResult Index()
{//return Content(Url.Action("index")); // /home//return Content(Url.Action("index", "home")); //  /homereturn Content(Url.Action("index", "course", new { id = 1, name = "lili" }));// /course/index/1?name=lili 和我想像/course/index?id=1&1name=lili不一样,有人知道吗?}

八、区域的使用

1、点击项目右键-》添加-》新搭建基架的项目-》MVC区域-》添加-》区域名称:Manage

 2、添加控制器视图

namespace FirstCoreMvc.Areas.Manage.Controllers
{[Area("Manage")] //需要添加区域注释,否则会和外边路由冲突public class HomeController : Controller{public IActionResult Index(){return View();}}
}

注意:[Area("Manage")]  需要添加区域注释,否则会和外边路由冲突

3、startup.cs文件中路由设置

//区域路由 放到上面routes.MapAreaRoute("mange_area","Manage","manage/{controller=Home}/{action=Index}/{id?}");

http://www.lryc.cn/news/224906.html

相关文章:

  • 前端设计模式之【访问者模式】
  • 通过docker-compose部署elk日志系统,并使用springboot整合
  • 【NLP】特征提取: 广泛指南和 3 个操作教程 [Python、CNN、BERT]
  • 数据结构-单链表
  • 红队系列-IOT安全深入浅出
  • 亚数受邀参加“长三角G60科创走廊量子密码应用创新联盟(中心)”启动仪式
  • 直方图学习
  • Java / Android 多线程和 synchroized 锁
  • 基于51单片机的万年历-脉搏计仿真及源程序
  • 【ARFoundation学习笔记】点云与参考点
  • uni-app:js实现数组中的相关处理-数组复制
  • 8 STM32标准库函数 之 实时时钟(RTC)所有函数的介绍及使用
  • ARMday04(开发版简介、LED点灯)
  • 国际腾讯云:云服务器疑似被病毒入侵问题解决方案!!!
  • Perl语言用多线程爬取商品信息并做可视化处理
  • 认识计算机-JavaEE初阶
  • you-get - 使用代码下载视频
  • 【Proteus仿真】【51单片机】汽车尾灯控制设计
  • 浙大恩特客户资源管理系统任意文件上传漏洞复现
  • 史上第一款AOSP开发的IDE (支持Java/Kotlin/C++/Jni/Native/Shell/Python)
  • GCC + Vscode 搭建 nRF52xxx 开发环境
  • Linux应用开发基础知识——Framebuffer 应用编程(四)
  • 智安网络|数据库入门秘籍:通俗易懂,轻松掌握与实践
  • EXCEL中安装多个vsto插件,插件之间互相影响功能,怎么解决
  • Java枚举
  • 基于MATLAB的关节型六轴机械臂轨迹规划仿真
  • 双11狂欢最后一天
  • YOLOX: Exceeding YOLO Series in 2021(2021.8)
  • HBuilderX 运行Android App项目至雷电模拟器
  • Java进阶(JVM调优)——阿里云的Arthas的使用 安装和使用 死锁查找案例,重新加载案例,慢调用分析