Sqli-LABS通关笔录-2

断了今生、忘了曾经 提交于 2019-11-27 04:32:08

在这个关卡学习到了

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语句,即可以成功执行。

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

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

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

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

 

 

 

 

 

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!