009_DI-Elec/Learun.Application.Web/App_Start/01 Handler/HandlerValidateAntiForgeryTokenAttribute.cs

42 lines
1.5 KiB
C#
Raw Permalink Normal View History

2025-08-13 11:14:39 +08:00
using System.Net;
using System.Web.Helpers;
using System.Web.Mvc;
namespace Learun.Application.Web
{
/// <summary>
/// 版 本 PIT-ADMS V7.0.3 敏捷开发框架
/// Copyright (c) 2013-2018 Hexagon PPM
/// 创建人:-框架开发组
/// 日 期2017.03.08
/// 描 述:防伪验证
/// </summary>
public class HandlerValidateAntiForgeryTokenAttribute:AuthorizeAttribute
{
/// <summary>
/// 拦截器
/// </summary>
/// <param name="filterContext">http上下文</param>
public override void OnAuthorization(AuthorizationContext filterContext)
{
var request = filterContext.HttpContext.Request;
if (request.HttpMethod == WebRequestMethods.Http.Post)
{
if (request.IsAjaxRequest())
{
var antiForgeryCookie = request.Cookies[AntiForgeryConfig.CookieName];
var cookieValue = antiForgeryCookie != null
? antiForgeryCookie.Value
: null;
//从cookies 和 Headers 中 验证防伪标记
//这里可以加try-catch
AntiForgery.Validate(cookieValue, request.Headers["__RequestVerificationToken"]);
}
else
{
new ValidateAntiForgeryTokenAttribute().OnAuthorization(filterContext);
}
}
}
}
}