Upgrade to Pro — share decks privately, control downloads, hide ads and more …

關於 HITCON CTF 的那些事 之 Web 狗如何在險惡的 CTF 世界中存活?

Orange
July 18, 2015

關於 HITCON CTF 的那些事 之 Web 狗如何在險惡的 CTF 世界中存活?

2015 烏雲峰會演講投影片

Orange

July 18, 2015
Tweet

More Decks by Orange

Other Decks in Technology

Transcript

  1. About Me • 蔡政達 a.k.a Orange • CHROOT 成員 /

    HITCON 成員 • 國內外研討會 HITCON, AVTokyo, PHPConf 等講師 • 國內外駭客競賽 CTF 冠軍 • 揭露過 Microsoft IE, Django, Yahoo ... 等 0-DAY 漏洞 • 專精於駭客手法、Web Security 與網路滲透 #90後 #賽棍 #電競選手 #狗 #Web狗
  2. About HITCON CTF Team • 台灣駭客年會 (Hacks in Taiwan Conference)

    • 前身為 CHROOT 讀書會 • 目前比賽成員約 14 位,成員來自台灣各隊伍 • 過半數為學生
  3. 參與過賽事(決賽) • 中國 BCTF • 韓國 SECUINSIDE • 美國 DEF

    CON • 馬來西亞 HITB • 日本 SECCON • 韓國 CODEGATE • 中國 0CTF • …
  4. • DEFCON CTF 22 Quals • 聚集各方戰力重新挑戰一次 • HITCON •

    台灣大學 217 • 交通大學成員 2014-05 2013-05 2014-05
  5. • HITCON 舉辦首場開放世界報 名的比賽 - HITCON CTF • 列強環繞 -

    Bamboo Fox 成立 2014-05 2013-05 2014-05 2014-07 2014-08 2014-08
  6. • 日本 SECCON 決賽 • Kill of the Hill 賽制

    • 看不懂規則以及網頁 • 花了兩個小時 Fuzzing Protocol 找到 Overflow 後... 原來有提供 Binary 2014-05 2013-05 2014-05 2014-07 2014-08 2014-08 2015-02
  7. DEFCON 22 CTF Quals Web x 1 of 21 DEFCON

    23 CTF Quals Web x 1 of 24 Boston Key Party CTF 2015 Web x 0 of 31 PLAID CTF 2015 Web x 1 of 24 「Web 狗如何在險惡的 CTF 世界中存活?」
  8. Web 為何弱勢? • 代碼數量 • 你不會為了出一道題目去寫幾十萬行代碼 • 技術 v.s. 思路

    v.s. ...滲透? • 漏洞利用的藝術 • 想想假使 WordPress / Discuz 出了一個任意變量覆蓋要如何 優雅 的利用? • 跳個 alert 也是利用,遠端代碼執行也是利用
  9. # login page r = query("SELECT pwd FROM users WHERE

    user = '%s'" % username) if r.pwd == password: session['username'] = username # index page username = session['username'] r = query("SELECT point FROM users WHERE user = '%s'" % username) print r.point CodeGate CTF 2015 Final Web Pseudo Code
  10. CodeGate CTF 2015 Final Web Pseudo Code • 4 /

    10 隊伍解出 • 技術很簡單,成功登入後可以看到 session 對應的分數 • 不過在沒有原始碼狀況下難度增加 • 對於黑箱測試來說只有登入成功以及失敗的結果可知 Q: 在沒有錯誤、無法讀寫、無法多語句的前提下,如何用最快的方式 取得資料?
  11. ' UNION SELECT (SELECT CASE WHEN random()*2>1 THEN 'password' ELSE

    (SELECT sql FROM sqlite_master limit 1) END)--+ 核心概念 - 單次輸入但構造出不同的結果
  12. ' UNION SELECT (SELECT CASE WHEN datetime('now')>'2015-06-22 00:00:00' THEN 'password'

    ELSE (SELECT sql FROM sqlite_master limit 1) END)--+ 核心概念 - 單次輸入但構造出不同的結果
  13. • 2 / 1020 隊伍解出 • Web 分層架構漏洞 • ColdFusion

    with Apache Connector • 舊版本 ColdFusion Double Encoding 造成資訊洩漏漏洞 • 同樣漏洞,出現兩種思路兩種解法 HITCON CTF 2014 Web LEENODE
  14. <FilesMatch "^\.ht"> 會被 Apache 處理 使⽤用 Double Encoding 繞過 Apache

    處理 .cfm 會被 JRun 處理 使⽤用 Null Byte 截斷 .cfm JRun 讀取 .htpasswd 原始碼並送回 /admin%252f%252ehtpasswd%2500.cfm
  15. /.%5Cadmin%5C.htpasswd%253b.jsp <FilesMatch "^\.ht"> 會被 Apache 處理 使⽤用反斜線繞過 Apache 處理 .jsp

    會被 JRun 處理 使⽤用 ; 截斷 .jsp JRun 讀取 .htpasswd 原始碼並送回
  16. 從用得上的實例學起 • Web Hacking • Reversing + Pwnable • /cgi-bin/

    下的 ELF • 嵌入式設備總會遇到 • 滲透後主機提權要自己改 Exploit Code • Cryptography • Padding Oracle / Bit Flipping Attack / Length Extension Attack ...
  17. Web 狗額外優勢 • 網頁端的資訊洩漏 ( Flag ? ) • /server-status/

    • /.git/ .DS_Store • 針對出題者的資訊蒐集? • 蒐集題目作者習慣 Code Snippet / Coding Style •還有哪些只有 Web 狗能做的事情?