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

asp.net core mvc区域路由

ASP.NET Core 区域路由(Area Routing)是一种将应用程序中的路由划分为多个区域的方式,类似于 MVC 的控制器和视图的区域划分。区域路由可以帮助开发人员更好地组织应用程序的代码和路由,并使其更易于维护。

要使用区域路由,在 ASP.NET Core 应用程序中需要进行以下配置:

  1. 在应用程序的 Startup.cs 文件中,添加区域路由的支持。在 ConfigureServices 方法中,添加以下代码:
services.AddControllersWithViews().AddRazorPagesOptions(options =>
{options.Conventions.AddAreaPageRoute("Admin", "/Index", "admin");
});
services.AddRazorPages();
  1. 在应用程序中创建一个或多个区域文件夹,例如 Areas/Admin。在该文件夹中,创建一个 Startup.cs 文件,用于配置该区域的路由。
public class Startup
{public void ConfigureServices(IServiceCollection services){services.AddControllersWithViews();}public void Configure(IApplicationBuilder app, IWebHostEnvironment env){app.UseEndpoints(endpoints =>{endpoints.MapControllerRoute(name: "admin_default",pattern: "{area:exists}/{controller=Home}/{action=Index}/{id?}");});}
}
  1. 在区域中创建控制器和视图,例如 Areas/Admin/Controllers/UsersController.csAreas/Admin/Views/Users/Index.cshtml。在控制器中,可以使用 Area 特性来指定该控制器属于哪个区域。
using Microsoft.AspNetCore.Mvc;[Area("Admin")]
public class UsersController : Controller
{public IActionResult Index(){return View();}
}
  1. 在视图中使用 Url.Action 生成区域路由的 URL。例如,在 Areas/Admin/Views/Users/Index.cshtml 视图中生成控制器的 URL 可以使用以下代码:
<a href="@Url.Action("Index", "Users", new { area = "Admin" })">Manage Users</a>

这样,当用户访问以 /Admin 开头的 URL 时,就会自动将路由映射到 Areas/Admin 区域中的控制器和视图。区域路由使得应用程序的代码和路由更加整洁、有序,并可以更好地组织和管理。

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

相关文章:

  • KNN(下):数据分析 | 数据挖掘 | 十大算法之一
  • Servlet开发-session和cookie理解案例-登录页面
  • Polygon Miden:扩展以太坊功能集的ZK-optimized rollup
  • [题]宝物筛选 #单调队列优化
  • .NET的键盘Hook管理类,用于禁用键盘输入和切换
  • Anaconda Jupyter
  • Unity中Shader的前向渲染路径ForwardRenderingPath
  • 简历项目优化关键方法论-START
  • TensorFlow学习1:使用官方模型进行图片分类
  • C++ 并发编程实战 第八章 设计并发代码 一
  • 设计模式8、装饰者模式 Decorator
  • 抖音开放平台第三方代小程序开发,一整套流程
  • Flutter笔记:滚动之-无限滚动与动态加载的实现(GetX简单状态管理版)
  • 前端架构师之02_ES6_高级
  • VScode多文件编译/调试配置
  • K折交叉验证——cross_val_score函数使用说明
  • 2023.09.30使用golang1.18编译Hel10-Web/Databasetools的windows版
  • React简介
  • 链表经典面试题(一)
  • 体验亚马逊的 CodeWhisperer 感觉
  • 6、行内元素和块元素
  • LeetCode 面试题 08.01. 三步问题
  • [CSCCTF 2019 Qual]FlaskLight 过滤 url_for globals 绕过globals过滤
  • 1分钟快速实现Redis数据对比
  • ASUS华硕天选4笔记本电脑FX507VV原厂Windows11系统
  • Vue3配置路由
  • 力扣 -- 97. 交错字符串
  • 【剑指Offer】4.二维数组中的查找
  • 独立按键控制LED亮灭、独立按键控制LED状态、独立按键控制LED显示二进制、独立按键控制LED移位——“51单片机”
  • chrome extensions mv3通过content scripts注入/获取原网站的window数据