XSS WebAPI solutions

重写DelegatingHandler的SendAsync方法进行过滤
public class AntiXssHttpMessageHandler : DelegatingHandler
{
protected override System.Threading.Tasks.Task SendAsync(HttpRequestMessage Request, System.Threading.CancellationToken cancellationToken)
{
foreach (var key in Request.RequestUri.ParseQueryString().AllKeys)
{
var value = Sanitizer.GetSafeHtmlFragment(Request.RequestUri.ParseQueryString()[key]);
if (value != Request.RequestUri.ParseQueryString()[key])
{
throw new Exception();
}
}
return base.SendAsync(Request, cancellationToken);
}
}

public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
config.Routes.MapHttpRoute(
name: “DefaultApi”,
routeTemplate: “api/{controller}/{id}”,
defaults: new { id = RouteParameter.Optional }
);

    config.EnableSystemDiagnosticsTracing();
    config.MessageHandlers.Add(new AntiXssHttpMessageHandler());
}

}
重写ApiControllerActionInvoker的InvokeActionAsync方法
public class XssActionInvoker : ApiControllerActionInvoker
{
public override Task InvokeActionAsync(HttpActionContext actionContext, CancellationToken cancellationToken)
{
//请求头参数处理—未实现

    Dictionary<string, object> changeDictionary = new Dictionary<string, object>();
    //上下文参数处理
    foreach (var para in actionContext.ActionArguments)
    {
        var paraType = para.Value.GetType();
        //string类型参数,一般为uri上的参数
        if (paraType == typeof(string))
        {
            var value = para.Value.ToString();
            if (!string.IsNullOrWhiteSpace(value))
            {
                value = Sanitizer.GetSafeHtmlFragment(value);//移除有危险的html标签 比如<script>
                //value = System.Web.HttpUtility.HtmlEncode(value);//将html标签进行编码
                changeDictionary.Add(para.Key, value);
            }
        }
        else if (paraType.IsClass)
        {
            var properties = paraType.GetProperties();
            bool flag = false;
            foreach (var e in properties)
            {
                if (e.PropertyType == typeof(string))
                {
                    var value = e.GetValue(para.Value) as string;
                    if (!string.IsNullOrWhiteSpace(value))
                    {
                        value = Sanitizer.GetSafeHtmlFragment(value);
                        e.SetValue(para.Value, value);
                        flag = true;
                    }
                }
            }
            if (flag)
            {
                changeDictionary.Add(para.Key, para.Value);
            }
        }
    }
    foreach (var para in changeDictionary)
    {
        actionContext.ActionArguments[para.Key] = para.Value;
    }
    return base.InvokeActionAsync(actionContext, cancellationToken);
}

}

protected void Application_Start()
{
GlobalConfiguration.Configuration.Services.Replace(typeof(IHttpActionInvoker), new XssActionInvoker());
}

本文转载自:https://www.cnblogs.com/cplemom/p/11247671.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值