Sql注入中 Group by rand() floor() Count(*)报错原理

Sql注入中 Group by rand() floor() Count(*)报错原理

一般组合为Group by floor(rand()*2)
rand() 是个伪随机函数,产生的随机数有一定的规律可循。例如:

select floor(rand(0)*2) from information_schema.columns;

这段语句产生的结果恒定不变始终是下面的序列:
在这里插入图片描述
结合count() 和group by 就可以爆出数据库名。

select count(*), concat(database(),floor(rand(0)*2)) as col from information_schema.columns Group by col;在这里插入图片描述
其原理是Count()group by()联合使用的时候会产生一个虚表

KeyValue
04
16

并且查询的时候如果使用rand()的话,该值会被计算多次,那这个“被计算多次”到底是什么意思?就是在使用group by的时候,floor(rand(0)*2)会被执行一次,如果虚表不存在记录,插入虚表的时候会再被执行一次。
floor(rand(0)*2)产生的序列如下

0110110011

处理上述序列流程如下
1、查询key时执行floor(rand(0)*2 = 0 不存在又执行一次得到 1 插入到虚表变为:

KeyValue
11

2、查询key时执行floor(rand(0)*2 = 1, 存在则将 1 插入到虚表变为:

KeyValue
11+1

3、查询key时执行floor(rand(0)*2 = 0, 不存在再执行一次将 1 插入到虚表。但是虚表中已经存在1这个索引所以报错。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值