• 技术文章 >后端开发 >php教程

    php sql防注入程序代码

    怪我咯怪我咯2017-07-12 15:18:58原创9723
    SQL注入攻击指的是通过构建特殊的输入作为参数传入Web应用程序,而这些输入大都是SQL语法里的一些组合,通过执行SQL语句进而执行攻击者所要的操作,其主要原因是程序没有细致地过滤用户输入的数据,致使非法数据侵入系统。

    根据相关技术原理,SQL注入可以分为平台层注入和代码层注入。前者由不安全的数据库配置或数据库平台的漏洞所致;后者主要是由于程序员对输入未进行细致地过滤,从而执行了非法的数据查询。基于此,SQL注入的产生原因通常表现在以下几方面:①不当的类型处理;②不安全的数据库配置;③不合理的查询集处理;④不当的错误处理;⑤转义字符处理不合适;⑥多个提交处理不当。

    本篇文章主要介绍一个通用的防注入代码,代码如下:

    function jk1986_checksql() 
    { 
    $bad_str = "and|select|update|'|delete|insert|*"; 
    $bad_Array = explode("|",$bad_str); 
    /** 过滤Get参数 **/ 
    foreach ($bad_Array as $bad_a) 
    { 
    foreach ($_GET as $g) 
    { 
    if (substr_count(strtolower($g),$bad_a) > 0) 
    { 
    echo "<script>alert('诡异字符,请不要尝试注入本站! 作者:Jk1986 QQ:414028660');location.href='index.php';</script>"; 
    exit(); 
    } 
    } 
    } 
    
    /** 过滤Post参数 **/ 
    
    foreach ($bad_Array as $bad_a) 
    { 
    foreach ($_POST as $p) 
    { 
    if (substr_count(strtolower($p),$bad_a) > 0) 
    { 
    echo "<script>alert('诡异字符,请不要尝试注入本站! 作者:Jk1986 QQ:414028660');location.href='index.php';</script>"; 
    exit(); 
    } 
    } 
    } 
    
    /** 过滤Cookies参数 **/ 
    
    foreach ($bad_Array as $bad_a) 
    { 
    foreach ($_COOKIE as $co) 
    { 
    if (substr_count(strtolower($co),$bad_a) > 0) 
    { 
    echo "<script>alert('诡异字符,请不要尝试注入本站! 作者:Jk1986 QQ:414028660');location.href='index.php';</script>"; 
    exit(); 
    } 
    } 
    } 
    }

    以上就是php sql防注入程序代码的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:php 代码 程序
    上一篇:简单的php防注入代码 下一篇:php中addslashes函数与sql防注入详解
    大前端线上培训班

    相关文章推荐

    • 怎样使用PHP中的spl_autoload_register() 和 __autoload() 函数?• 你必须了解PHP中什么是抽象类和抽象方法• PHP中怎样去判断对象是否属于一个类?• 五分钟带你看PHP中的接口interface声明与应用(实例详解)• PHP中怎样完成Cookie的创建、读取和删除?

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网