zoukankan      html  css  js  c++  java
  • 参数校验 防止SQL注射攻击一

    browser_pb Flock 推荐
    /// <summary>
            /// 参数校验 防止SQL注射攻击一
            /// 调用:object [] args = new object[6]{realname,address,areacode,contacttel,email,proviceid};
            ///    if(!BaseCheck.CheckParams(args))
            ///    {
            ///        Common.ShowDsMsg("您输入的内容不能通过");
            ///        return;
            ///    }
            /// </summary>
            /// <param name="args"></param>
            /// <returns></returns>
            public static bool CheckParams(params object[] args)
            {
                string[] Lawlesses={"=","'"};
                if(Lawlesses==null||Lawlesses.Length<=0)return true; //构造正则表达式,
                //例:Lawlesses是=号和'号,则正则表达式为 .*[=|'].* (由于是想做通用而且容易修改的函数,所以多了一步由字符数组到正则表达式,实际使用中,直接写正则表达式亦可;
                string str_Regex=".*[";
                for(int i=0;i< Lawlesses.Length-1;i++)
                    str_Regex+=Lawlesses[i]+"|";
                str_Regex+=Lawlesses[Lawlesses.Length-1]+"].*";
                foreach(object arg in args)
                {
                    if(arg is string)//如果是字符串,直接检查
                    {
                        if(Regex.Matches(arg.ToString(),str_Regex).Count>0)
                            return false;
                    }
                    else if(arg is ICollection)//如果是一个集合,则检查集合内元素是否字符串,是字符串,就进行检查
                    {
                        foreach(object obj in (ICollection)arg)
                        {
                            if(obj is string)
                            {
                                if(Regex.Matches(obj.ToString(),str_Regex).Count>0)
                                    return false;
                            }
                        }
                    }
                }
                return true;
            }
  • 相关阅读:
    窗内的星星
    亚特兰蒂斯
    你能回答这些问题吗
    区间最大公约数
    集训队8月14日(树状数组)
    一个简单的整数问题2
    谜一样的牛
    楼兰图腾
    Eternal Victory
    集训队8月12日(并查集)
  • 原文地址:https://www.cnblogs.com/twh/p/1394883.html
Copyright © 2011-2022 走看看