asp.net-mvc – MVC4区域和表单认证

我有一个MVC4应用程序设置了多个领域.每个区域都必须有自己的登录页面.比方说我有以下几个方面:

主要
管理员

如何设置它,使“主”区域有不同的登录页面到“管理”区域?我认为web.config不是这样的方式.

目前我的根web.config文件中有以下内容:

<authentication mode="Forms">
  <forms loginUrl="~/Admin/Login" timeout="2880" protection="Encryption" />
</authentication>

但是,我正在努力解决如何适应这个MVC4与区域.

请帮忙.

解决方法

我不知道是否可以使每个文件夹中的配置文件起作用.如果可以,请使用该解决方案.如果您不能,则可以使用自定义操作过滤器:

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生成每个区域的路由.那么你可以这样使用它:

[AreaAuthorize]
public ViewResult Index()
{
    return View("Index");
}

dawei

【声明】:唐山站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。