LoginSignup
3
0

More than 1 year has passed since last update.

ナゾトキCTF~入社試験からの脱出~ WriteUp

Last updated at Posted at 2022-07-18

はじめに

本記事は先日開催されたナゾトキCTF~入社試験からの脱出~に関するWriteupです。
Hintがあったおかげで無事に全問クリアできましたので私の解法例を記載します。
間違ってるところがあればご指摘いただけると嬉しいです。

ナゾトキCTF~入社試験からの脱出~ とは

  • 謎解き要素をミックスした初心者向けCTFイベント

  • イベント期間: 2022/7/17 (日) 13:00 JST - 2022/7/18 (祝) 13:00 JST

  • 形式: Online / Jeopardy??

  • ルール概要

    • フラグはカタカナ4文字
    • フラグを入手してポイントをゲット
    • 各問Hintが用意されていてポイントを消費することでHintを開放できる
  • なんとスポンサー様から賞品がでます!


解法例

おひつじ座

問題: あなたが目指しているものの間を読め

  • プロローグページより「あなた」=「高橋 ピヨ彦」が「目指しているもの」は「セキュリティ業界の星」
  • 「星」=「★」の間を読む
  • プロローグページのアイちゃんのメッセージに「★」が2つある
  • 「★」の間を縦に読むと「ハンドル」
    aries-ans.png

いきなり超難問でHintを見てもしばらくわからなかったです😂

おうし座

問題: 2021年に行われた、コンピューターウイルス「emotet」のテイクダウン作戦の名前を日本語で言うと?「○○○○ムシ作戦」

  • Emotetは2021/01/27に「Operation Ladybird」という作戦でテイクダウンに成功した

  • Ladybirdは日本語で「テントウ」ムシ

Emotetは活動再開しているのでご注意ください!!

ふたご座

問題: Webサイトにアクセスしフラグを探せ

  • ブラウザ上でパスワードを入力するサイトが提供されている
    gemini-inputPW.png

  • パスワードはdioskouroiらしいので入力してリクエストを覗いてみるとdummyPasswordrealPasswordというクエリを送っているのがわかる
    gemini-request.png

  • realPasswordの値をdioskouroiにしてリクエストを送ると「ナイーブ」というフラグが表示される
    gemini-flag.png

ちなみにdioskouroiはギリシャ神話の双子の神のことのようです ♊

かに座

問題: 仲間はずれを探せ (cancer.zip提供)

  • 提供されているcancer.zipを7zipで覗くと13個のファイルがあり、1つだけ妙に圧縮率の高いファイル"f0525aafa095ed2665d03681537a70ea"があったので開いてみるとファイルの最後に「イイワケ」と書かれている

  • 別解

    • 解凍したファイルをfileコマンドで確認しても仲間はずれは見つかりました。ちなみに残り12個はpcapng capture fileということなのでWireSharkなどで見れるパケットキャプチャファイルのようです。

      $ file *
      0961db32a59b8a83c1996498f9d1d80e: pcapng capture file - version 1.0
      397cbf6db9d7ae6906ae420aedc5346c: pcapng capture file - version 1.0
      44ca0844398b2d010d8cd4a31ddb023d: pcapng capture file - version 1.0
      4de447a391e32baeb5a52c55aa14467b: pcapng capture file - version 1.0
      550eadb88a230018bf043d1b6ad15863: pcapng capture file - version 1.0
      635cbc8a5dc1a528c3b5cb9eecdc1086: pcapng capture file - version 1.0
      7463543d784aa59ca86359a50ef58c8e: pcapng capture file - version 1.0
      766cc4dd4d5005652e8514e3513683f8: pcapng capture file - version 1.0
      7c70e2cb2b4a13c4590f6b15c30385fd: pcapng capture file - version 1.0
      a0678bcea04dbd6852c219062ab2bb3c: pcapng capture file - version 1.0
      b9c94e8a87e3647c5a0fa4ff358ecc65: pcapng capture file - version 1.0
      f0525aafa095ed2665d03681537a70ea: UTF-8 Unicode text
      f8a5c386478fa64f118056b82acc31d2: pcapng capture file - version 1.0
      

しし座

問題: ルールを守れ

  • 画像が提供されている
    leo-question.png

  • 「ルール」=ルールページの最後にある「大切なルール」
    leo-rule.png

  • ルール通りに「モエルゴミ」と「ペットボトル」は捨てていくと「チーター」がでてきた
    leo-ans.png

ルールのページに変なルールが書かれてるなぁ~ネタかなぁ~と思ったらここで使うルールでしたw

おとめ座

問題: Webアプリケーションのセキュリティ分野の研究・ガイドラインの作成・脆弱性診断ツールの開発・イベント開催などの活動をしているオープンソースソフトウェアコミュニティの名称の読み方をカタカナ4文字で答えよ。

  • OWASPなので「オワスプ」

てんびん座

問題: Webサイトにアクセスしフラグを探せ

  • サイトのメッセージを見るとstardustChromeという特殊なブラウザを使う(使っていると見せかける)必要がある
    libra-question.png

  • ブラウザ情報はUser-Agentヘッダで送信されるのでUser-Agentを偽装する

  • ChromeでUser-Agentを書き換える設定

    • 設定を開く
      libra-User-Agent.png

    • Use browser defaultのチェックをはずしてCustomの下にstardustChromeと設定する
      libra-User-Agent-Config.png

  • 再読み込みをクリックするとフラグ「クローン」が表示される

さそり座

問題: 世界一かわいいうちの犬を紹介します (scorpio.jpgが提供される)

  • わんこの画像が提供されている
    scorpio-question.png

  • かわいい

  • この子のきらきらおめめを拡大すると「カクダイ」という文字がうつっている

いて座

問題: 穴埋め

  • 穴埋めの画像が提供されている
    sagi-question.png

  • 東西南北。左側に英語読みが入り右側に音読みが入るので「イースト」

もはやノーヒントでは解けませんでした😵‍💫

やぎ座

問題: ある数 x を数 b のべき乗bᵖとして表した場合のpのこと。logとも呼ばれるこの数を日本語で何というか?カタカナ4文字で答えよ。

  • 対数なので「タイスウ」

みずがめ座

問題: Webサイトにアクセスしフラグを探せ

  • 「社員ナンバー」と「パスワード」を入力して社員情報を閲覧するサイトが提供されている
    aqu-question.png

  • プロローグページにアイちゃんの社員ナンバーが99と書かれているのでそれをつかう

  • パスワードはきっとSQL文で照合されるので入力文字列「1' or '1'='1」でSQLインジェクションを試みる

  • アイちゃんのプロフィールと主人公のプロフィールが表示され、フラグは主人公の苗字であることが書かれている。苗字は「タカハシ」

うお座

問題: みずがめ座からてんびん座に向かうとき、ひみつの鍵が手に入るだろう。水の中に浮かぶ真実を見定めよ。 (password.encとencrypt-pisces-new.zip(パスワード付きZIPファイル)が提供される)

  • みずがめ座(の問題で提供されたWebサイト)からてんびん座(の問題で提供されたWebサイト)へ向かうとき、ひみつの鍵が手に入る。ということで、みずがめ座のWebサイトからてんびん座のWebサイトへ訪問したという状況を作る

    • refererヘッダにはどこのサイトから訪れたかの情報が格納されているので、そこにみずがめ座の問題Webサイトを入れておく必要がある

    • ChromeのReferer Controlという拡張機能を使う。設定はこんな感じ。
      pis-referer.png

    • 上記設定後にてんびん座のWebサイトを訪れるとPrivate keyのデータが表示される

    ※ てんびん座の問題の時に設定したUser-Agentの設定は元に戻しておく(Use browser defaultにチェックを入れる)。そうしないとてんびん座の答えのページが表示されちゃいます。

  • 表示されたPrivate keyをpassword.encと同じディレクトリに例えばprivate.pemというファイル名で保存し、private.pemを使ってpassword.encを復号する

    $ openssl rsautl -decrypt -inkey private.pem -in password.enc
    The password for the zip is "fomalhaut".
    
  • encrypt-pisces-new.zipをパスワードfomalhautで解凍すると画像ファイルが見れます
    pisces.jpg

  • ステレオグラムなので後は頑張って見る…「ケッパク」

    ※ 実際の画像に黒い点を付けてみました。黒い点が重なるように焦点を奥または手前に少しずつずらしてみてください (私は奥に焦点を合わせる派)。そのまましばらくその焦点の距離で目を慣らします。焦点の距離に慣れてきたら焦点の距離は維持したそのままで視線を少し下げてみてください。ふんわり文字が浮かんでくることがあります。

ナゾトキとCTFが融合した感じがして面白かったです (難しかった…)

へびつかい座

問題: 最終問題に進むためのフラグを導く魔法の解答用紙をご用意しました(謎解きによくあるやつ)

  • 解答用紙
    ophiuchus-question.png

  • 12個のキーワードを入れて1文字目を繋げると良い

  • 12個なのでこれまでの12星座の答えを並べると「はてなをいちおくかいたたけ」
    ophiuchus-ans.png

  • 「はてな」はナゾトキxCTFの左上にある「?」アイコン。
    ophiuchus-hatena.png

  • これを1億回叩くとか無理(1秒に120回程度叩いても1日かかるし怒られるw)なので何か方法があるはず。ということで「?」アイコンを押す前と押した後のリクエストの差を眺める。

  • するとCookieのnazotokiの値が1ずつ増えているもよう。これを1億に書き換える。
    ophiuchus-cookie.png

  • 「?」を押すと「ポラリス」というフラグが表示される

最終問題

問題: パスワードを解け

※ ここに来るまでヒントをたくさん見てきたので最終問題は意地でもノーヒントで解く意気込みで頑張ってみる!💪

  • パスワードを入力するサイトが提供されている
    last-question.png

  • パスワードのヒントは愛の星座の中 => アイちゃんの星座の中にヒントがあると解釈する。

    • みずがめ座の問題でアイちゃんのプロフィールが閲覧できる

      7月18日生まれの「かに座」!かに座の問題の中にヒントがある。
      last-ai-prof.png

    • かに座の問題では1個の仲間外れのファイルと12個のパケットキャプチャファイルが提供されていた

      • 中身をのぞくとPNGファイルがFTP-DATAで転送されている
        last-pcap.png

      • PNGファイルを抽出して保存する
        last-4d-tcpstream.png
        last-4d-raw.png

      • 保存したPNGファイルを見ると星座の名前が書かれている。おそらく12個のキャプチャファイルに12個の星座の画像が入っていると思われる。
        last-4d.png

  • 流れに従い => パケットキャプチャの時刻順に星座を並べるということ??

    • え、大変(;´・ω・) めんどくさがりなのでここは一旦保留…
  • 太陽と月に背いて心の示す方を読め => 上記並べたとてコレがわからん

    • 偶然へびつかい座で使った解答用紙が目に入りしかも記号が書かれている。
      ophiuchus-ans.png

    • 太陽と月に背いて心の示す方を読め => 太陽マークと月マークの列ではなくハートマークに挟まれた列を読め、だと解釈する

      どとーわたすーだすすはぱ…

      きっと文字を並べ替えるのね…「ぱすわーど」が作れそう。

      残る文字は「とーたすーだすは」…「すたーだすと」が作れる。

      💡「ぱすわーど は すたーだすと」!!!🎊

  • パスワードにstardustを入れるとエヴoOOOOン風のお祝いメッセージで始まるエピローグページが表示された

    • ページの最後には最後のフラグ「オールト」
  • おまけ

    めんどくさがり発動で保留にしていたパケットキャプチャ時刻順での並べ替えをクリア後にやってみました。

    ちゃんと「ぱすわーどはすたーだすと」になりました😊

    キャプチャ時刻順 星座名 星座順 ハートマーク列の文字
    1 うお 12
    2 やぎ 10
    3 かに 4
    4 てんびん 7
    5 おひつじ 1
    6 みずがめ 11
    7 おとめ 6
    8 しし 5
    9 ふたご 3
    10 さそり 8
    11 いて 9
    12 おうし 2

    へびつかい座の解答にも最終問題の解答にもなるように12星座の答えが設計されているのは本当にすごいです👀


感想

単身で乗り込みフラグ入手でゲットしたポイントをHint開放で溶かしながら無事クリアできました。ナゾトキも面白くCTF初心者にも解きやすいように絶妙なHintが用意されていたおかげです😭

中でもしし座とうお座の問題が好きですw

へびつかい座と最終問題を解くと、それまでの問題のフラグとナゾトキの設計が本当にうまくできていることがわかります。楽しかったです😊

次回開催があればまた是非参加してみたいです!

3
0
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
0