У меня есть сценарий, который я не смог решить:
Я занимаюсь созданием собственного атрибута авторизации для mvc. Основной функционал, который я хотел бы добавить, - это возможность изменить место перенаправления пользователя, если он не в определенной роли. Я не против, чтобы система отправляла их обратно на страницу входа, если они не аутентифицированы, но я бы хотел выбрать, куда их отправлять, если они аутентифицированы, но не имеют доступа к этому методу действия.
Вот что я хотел бы сделать:
public class CustomAuthorizeAttribute : AuthorizeAttribute
{
public string Action;
public string Controller;
protected override bool AuthorizeCore(System.Web.HttpContextBase httpContext)
{
// if User is authenticated but not in the correct role
string url = Url.Action(this.Action, this.Controller);
httpContext.Response.Redirect(url);
}
}
И в качестве дополнительного бонуса я хотел бы получить доступ к ViewContext и TempData до того, как я выполню перенаправление.
Есть мысли о том, как мне создать экземпляр UrlHelper и ViewContext в атрибуте?