我有一个有两个领域的项目。这两个区域允许不共享任何控制器或视图的不同成员类型(例如学生和教师)。但是,它们都共享联系人和支持页面等的根控制器。
目前,我使用命名空间在每个区域内进行路由。
我想做这样的事情,但优先考虑命名空间,这样它们就不会有冲突的控制器:
context.MapRoute(
"Student_Default",
"{controller}/{action}/{id}",
new { area = "Student", controller = "Home", action = "Index", id = UrlParameter.Optional },
new { RoleConstraint = new AuthenticationConstraint() },
new[] { "Test.Web.Areas.Student.Controllers", "Test.Web.Controllers" }
);
或者,我尝试使用"UseNamespaceFallback",但在我不想要的所有区域中导致搜索。
我没有尝试过的其他事情是仅在用户登录时注册该区域。这是一种可以接受的方法吗?
此外,我可以只映射每个页面,但可能会有很多,而且做每个页面都会很混乱。
因此,问题是如何在区域彼此可用的情况下使根控制器可用于两个区域?如果需要更多信息,请告诉我,我很乐意提供更多关于我正在尝试做的事情的信息。
在周末考虑这个问题之后,我决定使用"UseNamespaceFallback"。我还实现了用户角色来管理每个用户有权访问的区域。我认为这是一种更好的方法,因为我已经阅读了永远不要使用命名空间作为身份验证方法的建议。