千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > sql注入原理及4中常见注入攻击代码分析

sql注入原理及4中常见注入攻击代码分析

来源:千锋教育
发布人:syq
时间: 2022-06-07 16:27:00 1654590420

  我们都知道,学安全,懂SQL注入是重中之重,因为即使是现在SQL注入漏洞依然存在,只是相对于之前现在挖SQL注入变的困难了。而且知识点比较多,所以在这里总结一下。

  通过构造有缺陷的代码,来理解常见的几种SQL注入。本文只是讲解几种注入原理,没有详细的利用过程。

  sql注入原理

  1.SQL注入漏洞的产生需要满足两个条件:

  2.参数用户可控:前端传给后端的参数内容是用户可以控制的。

  参数带入数据库查询:传入的参数拼接到SQL语句并带入数据库查询。所以在实际环境中开发者要秉持“外部参数皆不可信原则”进行开发。

  4种常见的sql注入攻击

  1、union注入攻击

  先看代码

<?php

$con=mysqli_connect("localhost","root","XFAICL1314","dvwa"); #连接数据库,我这里直接连接了dvwa的数据库
if(mysqli_connect_error())
{
    echo "连接失败:" .mysqli_connect_error();
}
$id=$_GET['id'];
$result=mysqli_query($con,"select * from users where `user_id`=".$id);
$row=mysqli_fetch_array($result);
echo $row['user'] . ":" . $row['password'];
echo "<br>";

  在union注入页面中,程序获取GET参数id,对用户传过来的id值没有进行过滤,直接拼接到SQL语句中,在数据库中查询id对应的内容,并将这一条查询结果中的user和password 输出到页面。进行union注入攻击前提是页面有回显。然后就是注入的常规思路,判断类型,判断字段数,使用union查询相关数据。

  2、布尔盲注攻击

  先看代码  

<?php
$con=mysqli_connect("localhost","root","XFAICL1314","dvwa");
if(mysqli_connect_error())
{
    echo "连接失败:" .mysqli_connect_error();
}
$id=$_GET['id'];
if(preg_match("/union|sleep|benchmark/i",$id)){
    exit("on");
}
$result=mysqli_query($con,"select * from users where `user_id`=".$id);
$row=mysqli_fetch_array($result);
if ($row) {
    exit("yes");
}
else{
    exit("no");
}
?>

  在布尔盲注页面中,程序先获取GET参数id,通过preg_match()函数判断其中是否存在union sleep benchmark等危险字符。然后将参数id拼接到SQL语句,从数据库查询,如果有结果,返回yes,否则返回no。

  所以访问这个页面,代码根据查询结果返回只返回yes和no,不返回数据库中的任何结果,所以上一种的union注入在这里行不通。

  尝试利用布尔盲注。布尔盲注是指构造SQL判断语句,通过查看页面的返回结果来推测哪些SQL判断是成立的。例如,我们可以判断数据库名的长度构造语句如下。and length(database())>=1 #依次增加,查看返回结果。

sql注入原理及4中常见注入攻击代码分析1736

sql注入原理及4中常见注入攻击代码分析1481

 

  通过上面的语句我们可以猜到数据库名长度为4。

  接着使用逐字符判断的方式获取数据库库名,数据库库名范围一般都是az,字母09。构造语句如下:

  and substr(database(),1,1)=要猜解的字母(转换成16进制)

  substr是截取的意思,构造语句的含义是,截取database()的值,从第一个开始,每次返回一个。这里要注意,要和limit语句区分开,limit从0开始排序,substr从1开始排序。因为我知道数据库的第一个字母是d,所以直接换成d,转换成16进制就是0x64。结果如下: 

sql注入原理及4中常见注入攻击代码分析1736 

  在真实环境中,自己手工的话,工作量有点大,可以借助burp的爆破功能爆破要猜解的字母。

  同样,也可以利用substr()来猜解表名和字段。构造语句:

  and substr((select table_name from information_schema.tables where table_schema=库名 limit 0,1),1,1)=要猜解的字母(这里指表名)

0

  用这样的方法,可以猜解出所有的表名和字段,手工会累死,可以借助burp或者sqlmap。

  3、报错注入攻击

  先看代码 

<?php
$con=mysqli_connect("localhost","root","XFAICL1314","dvwa");
if (mysqli_connect_error())
{
    echo "连接失败:".mysqli_connect_error();
}
$id=$_GET['id'];
if($result=mysqli_query($con,"select *from users where `user_id`=".$id))
{
    echo "ok";
}else{
    echo mysqli_error($con);
}
?>

  查看代码,在报错注入页面中,程序获取GET参数id后,将id拼接到SQL语句中查询,如果执行成功,就输出ok,如果出错,就通过echo mysqli_error($con)将错误信息输出到页面。我们可以利用这种错误回显,通过updatexml()、floor()等函数将我们要查询的内容显示到页面上。

  例如,我们通过updatexml()获取user()的值,构造如下语句:

  and updatexml(1,concat(0x7e,(select user()),0x7e),1) #0x7e是~16进制编码

  发现查询出了user()的值

sql注入原理及4中常见注入攻击代码分析2545

  同样,我们也可以查询出database()的值

  and updatexml(1,concat(0x7e,(select database()),0x7e),1) #0x7e是~16进制编码

  查询出了数据库名

sql注入原理及4中常见注入攻击代码分析2651

  我们可以用这种方法查询出剩下的所有表名和字段,只需要构造相关的SQL语句就可以了。

  4、时间盲注入攻击

  先看代码 

<?php
$con=mysqli_connect("localhost","root","XFAICL1314","dvwa");
if (mysqli_connect_error())
{
    echo "连接失败:".mysqli_error();
}
$id=$_GET['id'];
if (preg_match("/union/i",$id)){
    exit("<html><body>no</body></html>");
}
$result=mysqli_query($con,"select * from users where `user_id`=".$id);
$row=mysqli_fetch_array($result);
if ($row){
    exit("<html><body>yes</body></html>");
}
else{
    exit("<html><body>no</body></html>");
}
?>

  查看代码,在时间盲注页面中,程序获取GET参数id,通过preg_match()函数判断是否存在union危险字符,然后将id拼接到SQL语句中,并带入数据库查询。如果有结果返回yes,没有结果返回no。不返回数据库中的任何数据。

  它与布尔盲注的不同在于,时间盲注是利用sleep()或benchmark()等函数让执行时间变长。一般和if(expr1,expr2,expr3)结合使用,这里的if语句的含义为如果expr1为真,则if()返回expr2,否则返回expr3。所以判断数据库的长度,咱们构造的语句如下:

  if (length(database())>3,sleep(5),1) #判断数据库长度,如果大于3,休眠5秒,否则查询1 

sql注入原理及4中常见注入攻击代码分析3475

sql注入原理及4中常见注入攻击代码分析3473

  由上面图片,我们通过时间可以判断出,数据库的长度为4。

  得到长度后,通过substr()来查询数据库的第一个字母,这里和布尔盲注很类似,构造如下语句:

  and if (substr(database(),1,1)=库的第一个字母,sleep(5),1)

sql注入原理及4中常见注入攻击代码分析3605

  依次进行猜解。依次类推,可以猜解出数据库完整的库名,表名,字段名和具体数据。手工的话依旧是一个浩大的工程,一般借助工具。

  总结

  本文对union注入、布尔盲注、报错注入、时间盲注的原理和代码进行了简单的分析。

  更多关于网络安全的问题,欢迎咨询千锋教育在线名师。千锋教育多年办学,课程大纲紧跟企业需求,更科学更严谨,每年培养泛IT人才近2万人。不论你是零基础还是想提升,都可以找到适合的班型,千锋教育随时欢迎你来试听。

tags:
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT