3

我正在使用自定义过滤器来检查用户对特定操作的访问权限,并且我有一个名为 Admin 的区域。当过滤器重定向未经授权的用户时,它被重定向到内部区域而不是路由目录中的视图。
例如,当我访问http://localhost/admin/roles时,我希望未经授权的用户将被重定向到http://localhost/authorized而不是像现在这样重定向到 http: //localhost/admin/authorized
这是我使用过滤器的方法:

   public override void OnAuthorization(AuthorizationContext filterContext)
        {
            DigitalHubOnlineStoreEntities db = new DigitalHubOnlineStoreEntities();
            RbacUser requestingUser = new RbacUser();
            var controllerid = RbacUser.GetControllerId(filterContext.ActionDescriptor.ControllerDescriptor.ControllerName);
            var actionid = RbacUser.GetActionId(filterContext.ActionDescriptor.ActionName, controllerid);          
            if (!requestingUser.GetUserPermission(HttpContext.Current.User.Identity.Name, actionid, controllerid))
            {
                filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary { { "action", "Index" }, { "controller", "Unauthorized" } });
            }
        }
4

1 回答 1

11

您需要Area使用空字符串指定:

filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary
                       {
                           { "action", "Index" },
                           { "controller", "Unauthorized" },
                           { "Area", String.Empty }
                       });
于 2015-06-19T07:34:10.257 回答