我正在一些培训网页上学习sqlinjection(所以我不知道什么是后端)。我正在测试下一次注射以获得de db类型。
(1) http://url/?departamento=1 union select user()
这样,如果数据库是mysql,我应该得到一些结果。但是,我没有看到任何结果。如果我把注入改成这个新句子,数据就正确返回了,所以db是mysql(甚至我可以看到这个新注入的db名称):
(2) http://url/?departamento=1 union select 1,user()
然而,如果我再次改变注射方式,结果就会改变。
(3) http://url/?departamento=1 union select 1,2,user() (I don't see any data)
(4) http://url/?departamento=1 union select user(),2 (Here I don't see the DB name)
我不明白为什么我要添加(在第二个select语句中)更多的列来查看数据。为什么会这样?
谢谢!
1条答案
按热度按时间atmip9wb1#
假设后端是java,代码执行类似的操作:
为了使注入工作,需要生成有效的sql语句。
联合必须具有与源查询相同的列数
列类型必须匹配;第一个子查询中的列类型必须与第二个子查询中的列类型相同(某些数据库可能因此而导致查询失败)。
您的条件(“1”)必须与筛选器的右侧匹配(
departemento
)可能特定于java(以及本例),为了使循环工作,您需要能够将列强制转换为其目标类型。如果列1是一个数字,那么如果您的并集生成一个不能转换为数字的字符串,则可能永远无法显示其内容。