【问题标题】:Automating Anti Forgery Token Validation on MVC Apps在 MVC 应用程序上自动执行防伪令牌验证
【发布时间】:2015-08-15 15:25:55
【问题描述】:

有没有一种方法可以在控制器上的所有 HTTP post 方法上自动添加 [ValidateAntiForgeryToken] 注释,而无需显式定义它?

还有没有办法扩展 MVC Html.BeginForm() 助手以始终包含防伪令牌?

最后这样做的目的是为了在整个应用程序中保持一致,在某些情况下是否有理由不这样做?

【问题讨论】:

标签: c# asp.net-mvc asp.net-identity


【解决方案1】:

我自己正在研究这个主题,并在下面编译了完整的解决方案以及here。它由几个部分组成,包括AntiForgeryTokenFilterProviderBeginSecureForm 辅助方法。它还允许使用 DisableAntiForgeryCheckAttribute 跳过单个操作的验证。

public class AntiForgeryTokenFilterProvider : IFilterProvider
{
    public IEnumerable<Filter> GetFilters(ControllerContext controllerContext, ActionDescriptor actionDescriptor)
    {
        IEnumerable<FilterAttribute> filters = actionDescriptor.GetFilterAttributes(true);

        bool disableAntiForgery = filters.Any(f => f is DisableAntiForgeryCheckAttribute);

        string method = controllerContext.HttpContext.Request.HttpMethod;

        if (!disableAntiForgery
            && String.Equals(method, "POST", StringComparison.OrdinalIgnoreCase))
        {
            yield return new Filter(new ValidateAntiForgeryTokenAttribute(), FilterScope.Global, null);
        }
    }
}

[AttributeUsage(AttributeTargets.Method)]
public sealed class DisableAntiForgeryCheckAttribute : FilterAttribute
{
}

// Usage:
public class FilterConfig
{
    public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    {
        //**//
        FilterProviders.Providers.Add(new AntiForgeryTokenFilterProvider());
        //**//
    }
}

// Html Helper method
public static class HtmlExtensions
{
    public static MvcForm BeginSecureForm(this HtmlHelper html, string action, string controller)
    {
        var form = html.BeginForm(action, controller);
        html.ViewContext.Writer.Write(html.AntiForgeryToken().ToHtmlString());

        return form;
    }
}

【讨论】:

  • 优秀的总结,希望投票得更高。网络上散布着点点滴滴,但这将它们放在一起。
猜你喜欢
  • 2014-01-23
  • 1970-01-01
  • 2021-06-09
  • 2015-01-11
  • 2020-03-26
  • 1970-01-01
  • 2018-03-31
  • 2014-10-03
  • 2015-06-03
相关资源
最近更新 更多