在MVC应用程序上自动执行防伪标记验证

Ahs*_*san 7 c# asp.net-mvc asp.net-identity

[ValidateAntiForgeryToken]没有办法在控制器上的所有HTTP post方法上自动获取注释,而无需显式定义它?

还有一种方法可以随时扩展MVC Html.BeginForm()帮助程序以包含防伪标记吗?

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

Vad*_* K. 7

我研究这个话题我和下方,也可编制完整的解决方案在这里.它由几部分组成,包括AntiForgeryTokenFilterProviderBeginSecureFormhelper方法.它还允许跳过单个操作的验证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;
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 优秀的总结,希望这被投票更高。点点滴滴散落在网络上,但这将它们放在一起。 (2认同)