• 技术文章 >后端开发 >PHP问题

    php防sql注入原理

    (*-*)浩(*-*)浩2019-10-26 13:18:16原创944
    sql注入:就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。

    预处理语句针对SQL注入是非常有用的,因为参数值发送后使用不同的协议,保证了数据的合法性。预处理看作是想要运行的SQL的一种编译过的模板,它可以使用变量参数进行定制。 (推荐学习:PHP视频教程

    防御方法一

    mysql_real_escape_string – 转义SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集

    $sql = "select count(*) as ctr from users where username
    ='".mysql_real_escape_string($username)."' and
    password='". mysql_real_escape_string($pw)."' limit 1";

    方法二:

    打开magic_quotes_gpc来防止SQL注入。php.ini中有一个设置:magic_quotes_gpc =

    Off这个默认是关闭的,如果它打开后将自动把用户提交对sql的查询进行转换,比如把 ’ 转为 '等,对于防止sql注射有重大作用。

    如果magic_quotes_gpc=Off,则使用addslashes()函数。

    方法三:

    自定义函数

    function check_param($value=null) { 
     #select|insert|update|delete|\'|\/\*|\*|\.\.\/|\.\/|union|into|load_file|outfile
    $str = 'select|insert|and|or|update|delete|\'|\/\*|\*|\.\.\/|\.\/|union|into|load_file|outfile';
    if(!$value) {
            exit('没有参数!'); 
        }elseif(eregi($str, $value)) { 
            exit('参数非法!');
        } return true; 
    
    } 
    function str_check( $value ) {
       if(!get_magic_quotes_gpc()) { 
       // 进行过滤 
       $value = addslashes($value); 
       } 
       $value = str_replace("_", "\_", $value); 
      $value = str_replace("%", "\%", $value); 
       return $value; 
    
    } 
    function post_check($value) { 
            if(!get_magic_quotes_gpc()) {
        
      // 进行过滤  
                $value = addslashes($value);
            } 
            $value = str_replace("_", "\_", $value); 
            $value = str_replace("%", "\%", $value); 
            $value = nl2br($value); 
            $value = htmlspecialchars($value); 
            return $value; 
        }

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

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:php
    上一篇:php文件手机怎么打开 下一篇:php网站怎么修改图片
    PHP编程就业班

    相关文章推荐

    • php程序员能干到多少岁• PHP多久能学会?• php可以做游戏脚本吗• php可以做前端吗

    全部评论我要评论

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

    PHP中文网