CTF-报错注入

1. mysql 之count(*)原理

select count(*) from table group by floor(rand()*2);

sql表:table

idvalue
01
01
11
22
22
32

查询前mysql会建议一个虚拟表,查询表中第一行数据时,会insert floor(rand()*2),假如是0,查询虚拟表,发现不存在,则会再次执行floor(rand()*2),结果为1,插入虚表,这是第一条记录。

虚表(第1次查询)

idvalue
11

继续第二次查询,再次计算floor(rand()*2),发现为1,此时虚表中已经存在1,所以不会再次执行floor(rand()*2)

虚表(第2次查询)

idvalue
12

继续第二次查询,计算floor(rand()*2),发现为0,此时虚表中已经不存在0,所以会再次执行floor(rand()*2),

  • 假如计算为0,则可以正常插入

虚表(第3次查询)

idvalue
12
01
  • 假如为1,则会报错,因为重复了。
error info: Duplicate entry '1' for key '<group_key>'

floor(rand()*2)是不可测的。
在这里插入图片描述

2. 注入

公式:

select count(*),floor(rand()*2)x from information_schema.tables group by x;
# floor(rand()*2)x === floor(rand()*2) as x
报错函数
updatexml函数:
or udatexml(1concat(0x7e,(version())),0)
exp()
<>
regexp
like

实际使用

username updatexml
password (params)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值