ASP.Net MVC Core 2 - Маршрутизация области
Я пытаюсь реализовать Area
для администраторов в моем приложении ASP.Net MVC Core 2.
Я настроил маршрут для области следующим образом:
// Default route
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
// Admin area route
app.UseMvc(routes =>
{
routes.MapRoute(
name: "admin",
template: "{area=Admin}/{controller=Home}/{action=Index}/{id?}");
});
Это все работает довольно хорошо.
Этот админ area
использует то же самое Layout
в качестве основного веб-сайта, хотя _ViewStart.cshtml
живет в Areas/Admin/Views
каталог, но это все еще работает нормально.
У меня проблема с компонентом меню навигации, который находится в основном файле макета сайта и href
ссылки во всех якорях, указывающие на неправильный URL-адрес в области администратора.
Скажем, у меня есть следующие ссылки:
<a asp-controller="Account" asp-action="Index">My Account</a>
<a asp-controller="Shopping" asp-action="Basket">Shopping Basket</a>
<a asp-controller="Admin" asp-action="Users">Manage Users</a>
Находясь внутри области администратора, ссылки теперь относятся к области и, таким образом, выглядят так, как если бы они были следующими:
http://localhost/Admin/Account/Index
http://localhost/Admin/Shopping/Basket
http://localhost/Admin/Admin/Users
Есть ли хороший способ сделать все эти ссылки относительно корня сайта?
2 ответа
Есть пара вопросов, как вы настраиваете вещи в своем приложении.
- Вы не можете использовать
app.UseMvc()
дважды. Я думаю, что в основном последний переопределит вашу первую настройку. Вот почему вы видите все ссылки имеют/admin
префикс области. - Если вы хотите создать ссылку на управление пользователями в
admin
площадь, вы должны использоватьasp-area
вместо этого, как<a asp-area="admin" asp-controller="users" asp-action="index">Manage Users</a>
,
Вот как я буду настраивать области.
Маршрут области настройки, а также маршрут по умолчанию при запуске
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
// The area routing setup has to come before your default routing!
// Remember the order of these setups is very important!
// Mvc will use that template as soon as it finds a matching!
app.UseMvc(routes =>
{
routes.MapRoute(
name: "areaRoute",
template: "{area:exists}/{controller=dashboard}/{action=index}/{id?}"
);
routes.MapRoute(
name: "default",
template: "{controller=home}/{action=index}/{id?}"
);
}
Настройте базовый контроллер администратора с аннотацией [Area], чтобы вам не приходилось указывать это во всех других контроллерах, которые должны находиться в области администратора.
// Assume you have an Admin area under /Areas/Admin
namespace DL.SO.Web.UI.Areas.Admin.Controllers
{
[Area("admin")]
public abstract class AdminControllerBase : Controller
{
}
}
Контроллеры под админкой
// Dashboard controller. I know you have home controller inside
// your admin area but they should work the same.
namespace DL.SO.Web.UI.Areas.Admin.Controllers
{
public class DashboardController : AdminControllerBase
{
public IActionResult Index()
{
return View();
}
}
}
// Users controller. I know you have User(s) controller but I usually
// just keep the name of the controller singular.
namespace DL.SO.Web.UI.Areas.Admin.Controllers
{
public class UserController : AdminControllerBase
{
public IActionResult Index()
{
return View();
}
}
}
Укажите область с помощью помощника тега привязки
// My habit is to always specify the area with the anchor tag helper.
// For public links (those are not under any areas):
// I just pass empty string, like asp-area=""
// For links pointing to any controller under any area:
// Just pass the area, like asp-area="admin"
// http://localhost/account
<a asp-area="" asp-controller="account" asp-action="index">My Account</a>
// http://localhost/shopping/basket
<a asp-area="" asp-controller="shopping" asp-action="basket">Shopping Basket</a>
// http://localhost/admin/user
<a asp-area="admin" asp-controller="user" asp-action="index">Manage Users</a>
// http://localhost/admin/dashboard
<a asp-area="admin" asp-controller="dashboard" asp-action="index">Admin Panel</a>
Вы можете редактировать шаблон для URL, который будет отображаться как предпочтительный. т.е. изменить на
template: "{controller=Home}/{action=Index}/{id?}");