0
public class AdministratorAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
if (filterContext.HttpContext.User.Identity.IsAuthenticated)
{
EFUserRepository repo = new EFUserRepository();
var user = repo.FindUserByUserName(filterContext.HttpContext.User.Identity.Name);
if (user.UserRole.Name == "Administrator")
{
filterContext.Result = new RedirectToRouteResult(//Redirect to the original action they tried to enter?
}
}
else
{
//redirect to the "Home/Index" area.
}
}
}
我在重定向到此OnActionExecuting方法中的操作时遇到问题。另外,如果用户获得完全授权,我将如何将用户重定向到他们原来的预期行动。在实现ActionFilterAttribute的类中重定向
这[Administrator]
属性将被放置在许多不同的控制器,所以我必须有一种方法来重定向到他们试图达到适当的ActionResult。
你不能使用'Authorize'属性吗? '[Authorize(Roles =“Administrator”)]'? – Chris
我有我自己的自定义会员系统。 –