过滤不安全的字符串

来源:互联网 发布:java实施工程师做什么 编辑:程序博客网 时间:2024/05/21 17:36
/// /// 过滤不安全的字符串 /// /// /// public static string FilteSQLStr(string str) { if (str == String.Empty) return String.Empty; str = str.Replace("'", ""); str = str.Replace("\"", ""); str = str.Replace("&", "&"); str = str.Replace("<", "<"); str = str.Replace(">", ">"); str = str.Replace("delete", ""); str = str.Replace("update", ""); str = str.Replace("insert", ""); //单引号替换成两个单引号 str = str.Replace("'", "''"); //半角封号替换为全角封号,防止多语句执行 str = str.Replace(";", ";"); //半角括号替换为全角括号 str = str.Replace("(", "("); str = str.Replace(")", ")"); ///////////////要用正则表达式替换,防止字母大小写得情况//////////////////// //去除执行存储过程的命令关键字 str = str.Replace("Exec", ""); str = str.Replace("Execute", ""); //去除系统存储过程或扩展存储过程关键字 str = str.Replace("xp_", "x p_"); str = str.Replace("sp_", "s p_"); //防止16进制注入 str = str.Replace("0x", "0 x"); str = str.Replace("'", "‘"); str = str.Replace(";", ";"); str = str.Replace(",", ","); str = str.Replace("?", "?"); str = str.Replace("<", "<"); str = str.Replace(">", ">"); str = str.Replace("(", "("); str = str.Replace(")", ")"); str = str.Replace("@", "@"); str = str.Replace("=", "="); str = str.Replace("+", "+"); str = str.Replace("*", "*"); str = str.Replace("&", "&"); str = str.Replace("#", "#"); str = str.Replace("%", "%"); str = str.Replace("$", "¥"); //删除脚本 str = Regex.Replace(str, @"", "", RegexOptions.IgnoreCase); //删除HTML str = Regex.Replace(str, @"<(.[^>]*)>", "", RegexOptions.IgnoreCase); str = Regex.Replace(str, @"([\r\n])[\s]+", "", RegexOptions.IgnoreCase); str = Regex.Replace(str, @"-->", "", RegexOptions.IgnoreCase); str = Regex.Replace(str, @"
0 0
原创粉丝点击