前言
又是一年国赛,今年的国赛赛题质量大不如上一年,可能是上一年太菜了吧XD
今年的web题目很友好,作为在校期间最后一场比赛,玩的很开心。
Vegetable
打开题目是空白界面,查看源码发现是一张图片,保存本地,010editor打开发现有source.php
data:image/s3,"s3://crabby-images/c9bb2/c9bb21edfaca40cafa369b806f9889e1754b1eda" alt="2019国赛华东北赛区线下"
访问source.php发现源码:
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 43 44 45 46 47 48
| <?php class emmm { public static function checkFile(&$page) { $whitelist = ["source"=>"source.php","hint"=>"hint.php"]; if (! isset($page) || !is_string($page)) { echo "you can't see it"; return false; }
if (in_array($page, $whitelist)) { return true; }
$_page = mb_substr( $page, 0, mb_strpos($page . '?', '?') ); if (in_array($_page, $whitelist)) { return true; }
$_page = urldecode($page); $_page = mb_substr( $_page, 0, mb_strpos($_page . '?', '?') ); if (in_array($_page, $whitelist)) { return true; } echo "you can't see it"; return false; } }
if (! empty($_REQUEST['file']) && is_string($_REQUEST['file']) && emmm::checkFile($_REQUEST['file']) ) { include $_REQUEST['file']; exit; } else { echo "<div style=\"text-align:center;\"><br><img src=hint.png /></div>"; } ?>
|
看到有一个hint.php,访问得到提示:可以在vegetableflag得到flag
观察:
1 2 3 4 5
| $_page = mb_substr( $page, 0, mb_strpos($page . '?', '?') );
|
第一个问号之前的参数时候为source.php或者hint.php
heckFile函数的$_page取file参数的第一个问号前的字段,从而检查文件名是否在白名单内,构造file参数。
payload:index.php?file=source.php?/../../../../vegetableflag
data:image/s3,"s3://crabby-images/79550/7955006e246fba5e6bec9811679720fba0892486" alt="2019国赛华东北赛区线下"
后来才知道是HCTF2018的签到题 链接:https://blog.csdn.net/qq_40730518/article/details/84036753
DABAOJIAN
彩票系统…中彩票…类似的题之前已经出现好多次了,一般有三种思路:
1.json传参(2018QCTF出现)
2.整数溢出(2018护网杯)
3.重复注册
尝试发现,json传参构造即可
data:image/s3,"s3://crabby-images/3cb64/3cb6455407d98c514d3a366e6f7e43fe3dbcdf51" alt="2019国赛华东北赛区线下"
中彩,钱够了即可去买大宝剑2333
data:image/s3,"s3://crabby-images/b4b44/b4b4480d416a5c64622da6cc4bf170c6c8a93642" alt="2019国赛华东北赛区线下"
购买大宝剑得到后台路径
data:image/s3,"s3://crabby-images/a60bf/a60bfd86c621206e0aa36a128c71f62d686b6c4f" alt="2019国赛华东北赛区线下"
密码五位数,不知道,验证码用burp抓包绕过(验证码不变即可),爆破密码
data:image/s3,"s3://crabby-images/60cc8/60cc83f37b08540942f300aae14c950eaba10ce2" alt="2019国赛华东北赛区线下"
爆出密码09938,登录即可得到flag
data:image/s3,"s3://crabby-images/c3e28/c3e2843e4254570075dc0d7ca9c8eddd374601c3" alt="2019国赛华东北赛区线下"
Upload_2_shell
00截断绕过exif_imagetype的检测
先上传.htaccess,用php伪协议绕过<?
的检测
data:image/s3,"s3://crabby-images/9dc11/9dc119b71d03673f6422a935428e69e64f940020" alt="2019国赛华东北赛区线下"
上传base64编码过的shell
data:image/s3,"s3://crabby-images/483d1/483d1cc23481e047d3ea0bbc96da10791c8db053" alt="2019国赛华东北赛区线下"
Getshell,读flag
data:image/s3,"s3://crabby-images/1078f/1078fb3b51c89a66214f8fa189e2aee649a6a8b1" alt="2019国赛华东北赛区线下"