sql注入一点当心得

  很久没写技术博客,最近研究产品关于用户体验方面较多,加上项目忽然比较多,设计原型、跟进开发、设计师等工做着实没时间写博客。
  接下来技术上主要php深刻学习和mysql优化。这两天看了关于sql注入方面的知识,拿出来分享一下 :)
  
登陆注入
 

  
  先看一个咱们通常用的登陆页面sql语句(原生态php执行的sql)
$sql = "select * from users where username = '$username' and password = '$password'";

  对于这种sql,对应一个万能密码和用户名:php

    万能密码: xx' or 1='1
    万能用户名: xx' union select * from users/*
    执行时mysql解释为:
$sql = select * from users where username = '$username' and password = ' xx' or 1='1'

  不解释,瞬间破解mysql

  一样,上面是在sql语句中查询字段后的输入值加了单引号,有些时候尤为是初级程序员常常对变量不加单引号:程序员

 

$sql = "select * from users where username = $username and password = $password";    

 

  这时mysql解释会被当作数字型字段来匹配sql

     万能密码: 11 union select * from users/*
    执行语句:
select * from users where username = 11 union select * from users/* and password = 54
 
查询注入
 

  
  这个比较好理解,通常在页面的搜索框点击按钮搜索时在后台sql中可能会用like来查询,但若是没有加任何处理,可能输入一个% 或 __ 就会注入到sql中查询所有或部分记录,不过在php中可使用一个函数来处理一下:
$keyword = addslashes($keyword);
$keword = str_replace("%","\$",$kwyword);

插入注入
 

  
  咱们先模拟一个网站注册页面的sql处理语句:
insert into users(username,password,grade) values('frank','123456','1');
  假如users表中grade为等级字段,而且默认字段为1,注册时用户输入用户名和密码两个字段后,后台插入语句为上面语句,则当用户输入的密码为 123456','3')/*时,执行sql为:
insert into users(username,password,grade) values('frank','123456','3')/*,'1';
  这样也能够达到注入的目的
 
 
解决sql注入: 
 

     
  ①. 在服务器设置将php.ini配置文件中magic_quotes_gpc设置为On
          服务器会自动将单引号转义为:\'
          不过攻击时能够将单引号写为char(13)-单引号ASCII码,也同样能够攻击
 
     ②. 密码比对
          经过输入的用户名获取密码,再对密码进行匹配
          $sql  = "select * from users where username ='frank'"
          $result = mysql_query($sql,$conn);
          $row = mysql_fetch_array($result);
          if($row['password'] != $password) ...
 
      ③. 使用pdo的PDO::prepare()预处理操做
          PDO(PHP Data Object)扩展在PHP5中加入,PHP6默认识别PDO链接数据库,pdo至关因而一个数据库抽象层,不一样数据库使用相同的方法名,解决数据库链接不一样意问题。
          工做原理以下:
               
          (使用时需先在php.ini中开启对pdo扩展的支持)
      $sql = "select * from users where username=? and password=?";
          //建立一个pdo对象
          $mypdo = new PDO("mysql:host=localhost;port=3306;dbname=xx","root","123456");
          //设置编码
          $mypdo->exec("set names utf8");
 
          //预处理$sql
          $pdostatement = $mypdo->prepare(%sql);
          //将用户名和密码填入sql
          $pdostatement->execute(array($username,$password));
 
          //获得查询结果
          $result = $pdostatement->fetch();
 
          if(empty($result)) ...

 

     ④. 其余企业级解决sql注入方式:IDS(入侵检测系统)
 
          
 
  关于sql注入对于开发工程师来讲主要是防守,提升编写安全代码的意识,让咱们编写的代码质量更高,安全性方面更好。
相关文章
相关标签/搜索