我有一个MVC4应用程序设置了多个领域.每个区域都必须有自己的登录页面.比方说我有以下几个方面:
如何设置它,使“主”区域有不同的登录页面到“管理”区域?我认为web.config不是这样的方式.@H_404_4@
目前我的根web.config文件中有以下内容:@H_404_4@
<authentication mode="Forms"> <forms loginUrl="~/Admin/Login" timeout="2880" protection="Encryption" /> </authentication>
但是,我正在努力解决如何适应这个MVC4与区域.@H_404_4@
请帮忙.@H_404_4@
解决方法
我不知道是否可以使每个文件夹中的配置文件起作用.如果可以,请使用该解决方案.如果您不能,则可以使用自定义操作过滤器:
public class AreaAuthorizeAttribute : System.Web.Mvc.AuthorizeAttribute { protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext) { string area = filterContext.RouteData.Values.ContainsKey("area") ? filterContext.RouteData.Values["area"].ToString() : null; if (area == "Admin") { RouteValueDictionary routeValues = new RouteValueDictionary { {"controller","Login"},{"action","Index"},{"area","Admin"} }; filterContext.Result = new RedirectToRouteResult("AdminAreaRoute",routeValues); } else if (area == "User") { RouteValueDictionary routeValues = new RouteValueDictionary { {"controller","User"} }; filterContext.Result = new RedirectToRouteResult("UserAreaRoute",routeValues); } base.HandleUnauthorizedRequest(filterContext); } }
您可能需要修复路由名称,我不记得如果ASP.NET MVC生成每个区域的路由.那么你可以这样使用它:@H_404_4@
[AreaAuthorize] public ViewResult Index() { return View("Index"); }