IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> http访问拦截器,使用正则匹配request请求是否存在xxs攻击 -> 正文阅读

[网络协议]http访问拦截器,使用正则匹配request请求是否存在xxs攻击

http访问拦截器,过滤xxs构建的请求

public class HttpAccessInterceptModule : IHttpModule
    {
        private static List<string> _RegexWords;

        static HttpAccessInterceptModule()
        {
            _RegexWords = new List<string>()
            {
                @"<[^>]+>'",
                @"</[^>]+>'",
                @"<[^>]+?style=[\w]+?:expression\(|\b(alert|confirm|prompt|window|location|eval|console|debugger|Function|var|let)\b|^\+/v(8|9)|<[^>]*?=[^>]*?&#[^>]*?>|\b(and|or)\b.{1,6}?(=|>|<|\bin\b|\blike\b)|/\*.+?\*/|<\s*script\b|\bEXEC\b|UNION.+?SELECT|UPDATE.+?SET|INSERT\s+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)\s+(TABLE|DATABASE)"
            };
        }

        public void Dispose()
        {

        }

        public void Init(HttpApplication context)
        {
            context.PreSendRequestHeaders += OnPreSendRequestHeaders;
            context.BeginRequest += Context_BeginRequest;
        }

        private void OnPreSendRequestHeaders(object sender, EventArgs e)
        {
            try
            {
                if (sender is HttpApplication app)
                {
                    app.Response.Headers.Set("Server", "WebServer");
                    app.Response.Headers.Remove("X-AspNet-Version");
                    app.Response.Headers.Remove("X-AspNetMvc-Version");
                    app.Response.Headers.Remove("X-Powered-By");
                }
            }
            catch (Exception ex)
            {
                Log.Error(this, ex);
            }
        }

        private void Context_BeginRequest(object sender, EventArgs e)
        {
            if (sender is HttpApplication app)
            {
                try
                {
                    RequestFiller(app);
                }
                catch (Exception ex)
                {
                    Log.Error(this, ex);
                    app.Response.StatusCode = (int)HttpStatusCode.Forbidden;
                    app.Response.StatusDescription = HttpStatusCode.Forbidden.ToString();
                    app.Response.ContentType = "text/plain; charset=utf-8";
                    app.Response.ContentEncoding = Encoding.UTF8;
                    app.Response.Write("[ERROR][-1]操作失败,请求无法通过");
                    app.Response.End();
                }
            }
        }

        private void RequestFiller(HttpApplication app)
        {
            HttpRequest request = app.Request;
            WebUtils.GetClientHostAndAddress(request, out var userHostName, out var userHostIp);
            foreach (string key in request.Params.AllKeys)
            {
                string value = request.Params[key];
                if (!string.IsNullOrWhiteSpace(value) && key == "data")
                {
                    value = app.Server.HtmlDecode(value);
                }

                if (!string.IsNullOrWhiteSpace(key))
                {
                    foreach (string regex in _RegexWords)
                    {
                        if (Regex.IsMatch(key, regex, RegexOptions.IgnoreCase))
                            throw new BaseException($"存在访问风险,参数[{key}={value}]无法通过“{regex}”校验。远程客户端信息[{userHostName}{userHostIp}],请求地址[{request.Url}]。");
                    }
                }
                if (!string.IsNullOrWhiteSpace(value))
                {
                    foreach (string regex in _RegexWords)
                    {
                        if (Regex.IsMatch(value, regex, RegexOptions.IgnoreCase))
                            throw new BaseException($"存在访问风险,参数[{key}={value}]无法通过“{regex}”校验。远程客户端信息[{userHostName}{userHostIp}],请求地址[{request.Url}]。");
                    }
                }
            }

            if (request.Files.Count > 0)
            {
                foreach (string filesAllKey in request.Files.AllKeys)
                {
                    var fileData = request.Files[filesAllKey];
                    if (fileData == null || fileData.ContentLength == 0)
                        continue;
                    var exName = System.IO.Path.GetExtension(fileData.FileName);
                    if (!exName.IsCanUp())
                        throw new BaseException($"上传失败,不支持的文件扩展名[{exName}]。远程客户端信息[{userHostName}{userHostIp}],请求地址[{request.Url}]。");

                    var bytes = new byte[160];
                    fileData.InputStream.Read(bytes, 0, bytes.Length);
                    fileData.InputStream.Position = 0;

                    var pass = FileTypeCheck.IsValidFileExtension(fileData.FileName, bytes);
                    if (!pass)
                        throw new BaseException($"上传失败,[{fileData.FileName}]的文件格式不正确。远程客户端信息[{userHostName}{userHostIp}],请求地址[{request.Url}]。");


                    if (exName.ToLower().Contains("rar") || exName.ToLower().Contains("zip"))
                    {
                        var option = new ReaderOptions();
                        var encod = new ArchiveEncoding();
                        encod.Default = Encoding.Default;
                        option.ArchiveEncoding = encod;
                        var archive = ArchiveFactory.Open(fileData.InputStream, option);
                        foreach (var entry in archive.Entries)
                        {
                            if (!entry.IsDirectory)
                            {
                                string exTemp = System.IO.Path.GetExtension(entry.Key);
                                if (!exTemp.IsCanUp())
                                    throw new BaseException($"上传失败,压缩文件内容格式错误,不支持的文件扩展名[{exTemp}]。远程客户端信息[{userHostName}{userHostIp}],请求地址[{request.Url}]。");

                                var ms = new MemoryStream();
                                entry.WriteTo(ms);
                                pass = FileTypeCheck.IsValidFileExtension(entry.Key, ms.GetBuffer());
                                if (!pass)
                                    throw new BaseException($"上传失败,压缩文件内容[{entry.Key}]的文件格式不正确。远程客户端信息[{userHostName}{userHostIp}],请求地址[{request.Url}]。");
                                ms.Dispose();
                            }
                        }
                        fileData.InputStream.Position = 0;
                    }
                }
            }
        }
    }

在web.config的system.webServer节点下增加

<modules runAllManagedModulesForAllRequests="true">
      <remove name="HttpAccessInterceptModule"/>
      <add name="HttpAccessInterceptModule" type="Core.Commons.HttpAccessInterceptModule, Core.Commons"/>
    </modules>
  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-01-28 12:18:36  更:2022-01-28 12:19:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年10日历 -2024/10/6 13:25:11-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码