zoukankan      html  css  js  c++  java
  • 【转载】防范SQL注入式攻击

    SQL注入式攻击是利用是指利用设计上的漏洞,在目标服务器上运行Sql命令以及进行其他方式的攻击动态生成Sql命令时没有对用户输入的数据进行验证是Sql注入攻击得逞的主要原因。

    比如:
    如果你的查询语句是
    1 select * from admin where username="&user&and password="&pwd&""
    2 
     那么,如果我的用户名是:1 or 1=1
     那么,你的查询语句将会变成:
    1 select * from admin where username=1 or 1=1 and password="&pwd&""
    2 
    这样你的查询语句就通过了,从而就可以进入你的管理界面。

    所以防范的时候需要对用户的输入进行检查。特别式一些特殊字符,比如单引号,双引号,分号,逗号,冒号,连接号等进行转换或者过滤。

    需要过滤的特殊字符及字符串有:

    net user
       xp_cmdshell
       /add
       exec master.dbo.xp_cmdshell
       net localgroup administrators
       select
       count
       Asc
       char
       mid
       
       :
       
    "
       insert
       delete from
       drop table
       update
       truncate
       from
       %

    下面关于解决注入式攻击的防范代码,供大家学习参考!

    js版的防范SQL注入式攻击代码:

    <script language="javascript">
    <!--
     
    var url = location.search;
     
    var re=/^\?(.*)(select%20|insert%20|delete%20from%20|count\(|drop%20table|update%20truncate%20|asc\(|mid\(|char\(|xp_cmdshell|exec%20master|net%20localgroup%20administrators|\"|:|net%20user|\|%20or%20)(.*)$/gi;
     var e = re.test(url);
     if(e) {
      alert(
    "地址中含有非法字符~");
      location.href=
    "error.asp";
     }
    //-->
    <script> 


    C# 检查字符串,防SQL注入攻击
    这个例子里暂定为=号和号
     1 bool CheckParams(params object[] args)
     2 {
     3     string[] Lawlesses={"=",""};
     4     if(Lawlesses==null||Lawlesses.Length<=0)return true;
     5     //构造正则表达式,例:Lawlesses是=号和号,则正则表达式为 .*[=}].*  (正则表达式相关内容请见MSDN)
     6     //另外,由于我是想做通用而且容易修改的函数,所以多了一步由字符数组到正则表达式,实际使用中,直接写正则表达式亦可;
     7 
     8 
     9     string str_Regex=".*[";
    10     for(int i=0;i< Lawlesses.Length-1;i++)
    11         str_Regex+=Lawlesses[i]+"|";
    12     str_Regex+=Lawlesses[Lawlesses.Length-1]+"].*";
    13     //
    14     foreach(object arg in args)
    15     {
    16         if(arg is string)//如果是字符串,直接检查
    17         {
    18             if(Regex.Matches(arg.ToString(),str_Regex).Count>0)
    19             return false;
    20         }
    21         else if(arg is ICollection)//如果是一个集合,则检查集合内元素是否字符串,是字符串,就进行检查
    22         {
    23             foreach(object obj in (ICollection)arg)
    24             {
    25                 if(obj is string)
    26                 {
    27                     if(Regex.Matches(obj.ToString(),str_Regex).Count>0)
    28                     return false;
    29                 }
    30             }
    31         }
    32     }
    33     return true;
    34 
    35 
    转载自:http://blog.csdn.net/zuoyefeng_com/archive/2007/05/23/1623368.aspx
  • 相关阅读:
    dotnet core 获取 MacAddress 地址方法
    dotnet core 获取 MacAddress 地址方法
    dotnet core 发布只带必要的依赖文件
    dotnet core 发布只带必要的依赖文件
    Developing Universal Windows Apps 开发UWA应用 问答
    Developing Universal Windows Apps 开发UWA应用 问答
    cmd 如何跨驱动器移动文件夹
    cmd 如何跨驱动器移动文件夹
    C++ 驱动开发 error LNK2019
    C++ 驱动开发 error LNK2019
  • 原文地址:https://www.cnblogs.com/kay/p/767230.html
Copyright © 2011-2022 走看看