如何解决如何根据 MVC 中的自定义身份验证过滤器中的角色将经过身份验证的用户重定向到特定的控制器操作
公共类 CustomAuthenticationFilter : ActionFilterattribute,IAuthenticationFilter
{
public void OnAuthentication(AuthenticationContext filterContext)
{
如果(filterContext.HttpContext.User.Identity.IsAuthenticated)
{
if (System.Web.HttpContext.Current.User.IsInRole("Admin"))
{
filterContext.Result = new RedirectToRouteResult(
new RouteValueDictionary
{
{ "controller","Home" },{ "action","Index" }
});
}
else if (System.Web.HttpContext.Current.User.IsInRole("Teacher"))
{
filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary{{ "controller","Teacher" },"Index" }});
}
else if (System.Web.HttpContext.Current.User.IsInRole("Student"))
{
filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary{{ "controller","Student" },"Index" }});
}
else
{
filterContext.Result = new HttpUnauthorizedResult();
}
}
else
{
filterContext.Result = new HttpUnauthorizedResult();
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。