Sqli-LABS通关笔录-2

本文介绍了在特定场景下如何利用SQL注入技巧绕过程序验证,包括使用单引号和负号构造有效SQL语句的方法,解释了这两种情况下出现的错误类型及其解决思路。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这个关卡学习到了

1.程序的错误不是学校收费乱来的,单引号的错误和减号的错误要明白

 

 单引号报错。

用第一关的PAYLOAD尝试了下。

来看看源码:

那么我们构造的sql也就变成了

$sql="SELECT * FROM users WHERE id=1' or 1=1 --+ LIMIT 0,1";

如此一来id=1'就不被执行,语句也就成了:

$sql="or 1=1 --+ limit 0,1";

用mysql测试一下,如下图。的确如此!

那么单引号不行就换负号,就是减号呗。

这回自然是可以了。

完整的sql语句如下:

$sql="SELECT * FROM users WHERE id=-1 or 1=1 --+ LIMIT 0,1";

最终执行的mysql语句为:

select * from users where 1=1 --+ limit 0,1;该条语句是一条有效的sql语句,即可以成功执行。

这里需要理解的是单引号的错误负号的错误是什么概念。

单引号的错误是指语法错误

负号的是因为不存在而提示的错误

如此知道了缘故那么继续操作哈。

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值