asp.net MVC antiforgerytoken on exception RedirectToAction

后端 未结 2 1816
梦如初夏
梦如初夏 2021-02-08 05:11

I have implimented the AnitforgeryToken with my asp.net MVC forms, and also added the attribute to my login procedure, however when the check failes i wish to redirect to my fra

相关标签:
2条回答
  • 2021-02-08 05:33

    In case you do not want to put [HandleError] attribute on all actions that have [ValidateAntiForgeryToken], you may add a custom filter to your Global filters:

    in Global.asax under Application_Start():

    FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    

    and then:

    public class FilterConfig
    {
        public static void RegisterGlobalFilters(GlobalFilterCollection filters)
        {
            filters.Add(new HandleErrorAttribute());
            filters.Add(new AntiForgeryTokenFilter());
        }
    }
    

    AntiForgeryTokenFilter.cs:

    public class AntiForgeryTokenFilter : FilterAttribute, IExceptionFilter
    {
        public void OnException(ExceptionContext filterContext)
        {
            if(filterContext.Exception.GetType() == typeof(HttpAntiForgeryException))
            {
                filterContext.Result = new RedirectResult("/"); // whatever the url that you want to redirect to
                filterContext.ExceptionHandled = true;
            }
        }
    }
    
    0 讨论(0)
  • 2021-02-08 05:46

    The ValidateAntiForgeryTokenAttribute will just throw HttpAntiForgeryException. You could use the HandleErrorAttribute to handle this scenario:

    [HandleError(
        ExceptionType = typeof(HttpAntiForgeryException), 
        View = "Unauthorized")]
    [ValidateAntiForgeryToken]
    [AcceptVerbs(HttpVerbs.Post)]
    public ActionResult SomeActionThatRequiresToken() 
    {
        return View();
    }
    
    0 讨论(0)
提交回复
热议问题