首页主机资讯asp网站服务器如何过滤xss攻击

asp网站服务器如何过滤xss攻击

时间2023-04-24 09:30:04发布访客分类主机资讯浏览167
导读:asp网站服务器如何过滤xss攻击 asp网站服务器过滤xss攻击的方法:1、在web.config增加httpModules节点;2、编...

asp网站服务器如何过滤xss攻击

asp网站服务器过滤xss攻击的方法:1、在web.config增加httpModules节点;2、编写一个过滤器,过滤危险关键词,并增加安全的header。

下面是详细介绍:

1、在web.config增加httpModules节点

httpModules>
    

add name="HttpAccessInterceptModule" type="Org.Core.Commons.HttpAccessInterceptModule, Org.Core.Commons"/>

/httpModules>

2、再编写一个过滤器

using System;
    

using System.Collections.Generic;

using System.Configuration;

using System.Linq;

using System.Text.RegularExpressions;

using System.Web; namespace Org.Core.Commons

{

/// summary>

/// http访问拦截器模块

/// 1.过滤危险关键词

/// 2.增加安全Header

/// /summary>

public class HttpAccessInterceptModule : IHttpModule

{

private static Liststring>  _RegexWords;

static HttpAccessInterceptModule()

{

_RegexWords = new Liststring> ()

{

@"[^> ]+> '", 

@"/[^> ]+> '",

@"[^> ]+?style=[w]+?:expression(|(alert|confirm|prompt|window|location|eval|console|debugger|new|Function|var|let)|^+/v(8|9)|[^> ]*?=[^> ]*?& #[^> ]*?> |(and|or).{ 1,6} ?(=|> ||in|like)|/*.+?*/|s*script|EXEC|UNION.+?SELECT|UPDATE.+?SET|INSERTs+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)s+(TABLE|DATABASE)"

} ;

string[] keyWords = {  } ;

//{ "'", "alert", "script","case","catch","const","continue","debugge","delete","export*","final","finally","for","function","goto","if","implements","import*","return","switch","synchronized","throw","throws","transient","try","break"}

//new string[] {  "select", "insert", "update", "delete", "drop", "truncate" } ; _RegexWords.AddRange(keyWords.Select(o =>  @"(^|(W+))" + o + @"((W+)|$)"));

} public void Dispose()

{

} public void Init(HttpApplication context)

{

context.BeginRequest += new EventHandler(Context_BeginRequest);

context.EndRequest += new EventHandler(Context_EndRequest);

} private void Context_BeginRequest(object sender, EventArgs e)

{

HttpApplication app = (HttpApplication) sender;

try

{

if (IgnoreRequest(app.Request.CurrentExecutionFilePath))

return; RequestFiller(app.Request);

AddHeader(app.Response);

}

catch (Exception ex)

{

if (!(ex is PSBaseException))

PSLog4net.Error(this, ex);

app.Response.Write(ex.Message);

app.Response.Flush();

app.Response.End();

}

} private void Context_EndRequest(object sender, EventArgs e)

{

HttpApplication app = (HttpApplication) sender; SetContentType(app);

} private void RequestFiller(HttpRequest request)

{

string error = ""; if (request.Path.IndexOf("/log/", StringComparison.CurrentCultureIgnoreCase) > = 0)

error = "不允许访问/log/目录";

if (string.IsNullOrEmpty(error) & &

request.Path.IndexOf("/bak/", StringComparison.CurrentCultureIgnoreCase) > = 0)

error = "不允许访问/bak/目录";

if (string.IsNullOrEmpty(error))

{

foreach (string key in request.Params.AllKeys)

{

if (key == "aspxerrorpath")

continue;

string value = request.Params[key];

if (!string.IsNullOrEmpty(value) & &  (value.Contains("jquery.alert") || value.Contains("image")))

continue;

if (!string.IsNullOrEmpty(key))

{

//if (Regex.IsMatch(key, @"W+"))

//{

// error = string.Format("存在访问风险,参数[{ 0} ={ 1} ]没法通过“{ 2} ”校验.", key, value, @"W+");

// break;

//}

foreach (string regex in _RegexWords)

{

if (Regex.IsMatch(key, regex, RegexOptions.IgnoreCase))

{

error = $"存在访问风险,参数[{ key} ={ value} ]没法通过“{ regex} ”校验.";

break;

}

}

} if (!string.IsNullOrEmpty(error))

break;

if (!string.IsNullOrEmpty(value))

{

foreach (string regex in _RegexWords)

{

if (Regex.IsMatch(value, regex, RegexOptions.IgnoreCase))

{

error = $"存在访问风险,参数[{ key} ={ value} ]没法通过“{ regex} ”校验.";

break;

}

}

} if (!string.IsNullOrEmpty(error))

break;

}

} if (!string.IsNullOrEmpty(error))

{

Log4net.Error(this, error);

throw new PSBaseException("存在访问风险,要求没法通过系统校验规则.");

}

} private void AddHeader(HttpResponse response)

{ } private void SetContentType(HttpApplication app)

{

if (app.Request.Url.AbsolutePath.EndsWith(".png", StringComparison.CurrentCultureIgnoreCase))

app.Response.ContentType = "image/png";

if (string.IsNullOrEmpty(app.Response.ContentType))

app.Response.ContentType = "text/plain;  charset=utf⑻";

} private bool IgnoreRequest(string requestPath)

{

if (requestPath.EndsWith(".assx", StringComparison.CurrentCultureIgnoreCase) ||

requestPath.EndsWith(".sjs", StringComparison.CurrentCultureIgnoreCase) ||

requestPath.EndsWith(".asmx", StringComparison.CurrentCultureIgnoreCase))

return true;

else

return false;

}

}

}

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: asp网站服务器如何过滤xss攻击
本文地址: https://pptw.com/jishu/7164.html
美国服务器租用网站比较好的是哪个? 大带宽服务器租用要有哪些需要注意的

游客 回复需填写必要信息