采用Global.asax的Application_BeginRequest事件过滤敏感字符

1、特殊字符过滤公共类ProcessRequest.cs

using System.Web.UI;   
using System.Web.UI.WebControls;   
using System.Web.UI.WebControls.WebParts;   
using System.Web.UI.HtmlControls;   
  
namespace COMP   
{   
public class ProcessRequest   
{   
     public void StartProcessRequest()   
        {   
            try  
            {   
                string getkeys = "";   
                string sqlErrorPage = "/";   
                if (System.Web.HttpContext.Current.Request.QueryString != null)   
                {   
  
                    for (int i = 0; i < System.Web.HttpContext.Current.Request.QueryString.Count; i++)   
                    {   
                        getkeys = System.Web.HttpContext.Current.Request.QueryString.Keys[i];   
                        if (!ProcessSqlStr(System.Web.HttpContext.Current.Request.QueryString[getkeys].ToLower()))   
                        {   
                            System.Web.HttpContext.Current.Response.Redirect(sqlErrorPage);   
                            System.Web.HttpContext.Current.Response.End();   
                        }   
                    }   
                }   
  
                 
  
            }   
            catch  
            {   
                   
            }   
        }   
        /**/  
        /// <summary>   
        /// 分析用户请求是否正常   
        /// </summary>   
        /// <param name="Str">传入用户提交数据</param>   
        /// <returns>返回是否含有SQL注入式攻击代码</returns>   
        private bool ProcessSqlStr(string Str)   
        {   
            bool ReturnValue = true;   
            try  
            {   
                if (Str != "" && Str != null)   
                {   
                    string SqlStr = "";   
                    if (SqlStr == "" || SqlStr == null)   
                    {   
                        SqlStr = "'|and|exec|insert|select|delete|update|count|*|chr|mid|master|truncate|char|declare";   
                    }   
                    string[] anySqlStr = SqlStr.Split('|');   
                    foreach (string ss in anySqlStr)   
                    {   
                        if (Str.IndexOf(ss) >= 0)   
                        {   
                            ReturnValue = false;   
                        }   
                    }   
                }   
            }   
            catch  
            {   
                ReturnValue = false;   
            }   
            return ReturnValue;   
        }   
  
  
    }   
}  


 

2、Global.asax的Application_BeginRequest事件

 void Application_BeginRequest(object source, EventArgs e)
    {

        COMP.ProcessRequest pr = new COMP.ProcessRequest();
        pr.StartProcessRequest();
    } 


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值