我正在使用自定义过滤器来检查用户对特定操作的访问权限,并且我有一个名为 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" } });
}
}