Hostの環境構築と、いずれかのGuestの環境構築を行うこと。
Ghidraをインストールすること。
- 最新のversionのものでよい。
- Ghidra releases
- JDKのVersionに注意
WSL
, Vagrant+VirtualBox
, Docker
, Lima
の4つの方法を用意しています。各OS毎に動かせる環境は以下の通り。
- Windows -> WSL
- Mac (Intel) -> Vagrant + VirtualBox, Docker, Lima
- Mac (Arm) -> Lima
- Linux -> Vagrant + VirtualBox, Docker
いくつかのコマンドをデフォルトでinstallしないようにしました。これまでの全てのinstallを行いたい場合は、以下のコマンドを実行してください。
mv ./.gdbinit ./.gdbinit.reserve
mv ./.bashrc ./.bashrc.reserve
mv ./install.sh ./install.sh.reserve
mv ./command_chk.sh ./command_chk.sh.reserve
cp ./install-all/.gdbinit-all ./.gdbinit
cp ./install-all/.bashrc-all ./.bashrc
cp ./install-all/install-all.sh ./install.sh
cp ./install-all/command_chk-all.sh ./command_chk.sh
Windowsを使っている人のみWSLを使うことができる。
[host]
- ubuntu22.04をインストールする
[ubuntu22.04]
- 下記のコマンドを実行するだけでよい。
~/pwn
ディレクトリができているはず。
git clone https://github.com/iwashiira/sig-beginners-pwn-public.git
cd ./sig-beginners-pwn-public
./install.sh
[tree]
/root
├── .gdbinit
├── .gdbinit-gef.py
└── pwn
└── Tools -> /home/user/pwn/Tools
/home/user
├── .bashrc
├── .gdbinit
└── pwn
└──Programs
└── Tools
└── pwndbg
Arm Macを使っている人はVagrantを使うことはできない。
[host] Vagrant,Virtualboxをそれぞれインストールすること。
-
generic/ubuntu2204を使う
-
必要なVagrantfileを持ってくる。
-
Vagrantfileの割り当てるcpuの数、メモリ、名前は適宜自分の環境に合わせる。
git clone https://github.com/iwashiira/sig-beginners-pwn-public.git
cd sig-beginners-pwn-public
- VirtualboxのInstall
[vagrant] このリポジトリ内のVagrantfileを使う
# VMを起動
# AntiVirusソフトが動いていると上手くいかないことがあるのでその時は一時的に止める。
vagrant up
# 初回はprovisionが走る
# VM内に入る。
vagrant ssh
# VMからでる
Ctrl-D
# VMを落とす
# VMから出たあとに行う
vagrant halt
- Arm Macを使っている人はこの方法を利用できない。ptraceがサポートされておらず、gdbを使えないので。
- Dockerfile等はWindows用には作っていない。
[host] Dockerとdocker-composeをインストール
- DockerのInstall
- docker-composeのInstallation
- 最近は、dockerをInstallすると、composeのサブコマンドが付随してInstallされていることが多い
- docker compose Installation
[docker] このリポジトリ内のDockerfileとdocker-compose.ymlを使います。環境が立ち上がるまでに時間がかかる。
- コンテナ内での操作は~/pwn/Programsディレクトリの上のものしか保存されない。ほかの場所に作ったファイルはコンテナそのものを削除してしまったときに一緒に消える。
- エディタはvimとneovimが入っています。
# Docker for Macを使っている場合は、Launchpadからappを起動してdockerとdocker-composeを使えるようにする。
# 必要なDockerの設定ファイルを持ってくる。
git clone https://github.com/iwashiira/sig-beginners-pwn-public.git
cd sig-beginners-pwn-public
# .envファイルを作成するほか、./Programsディレクトリのパーミッションをrwxにする。
./set_dotenv.sh
chmod 777 ./Programs
# dockerのコンテナを作る。pwn_ubuntu2204は好きな名前にしてよい。かなり時間がかかるが、その代わり別でaptして何かをインストールする必要はない。再ビルドもこれ。
docker-compose -p pwn_ubuntu2204 build --no-cache
# composeサブコマンドの場合
docker compose -p pwn_ubuntu2204 build --no-cache
# 以降コンテナの操作 docker-compose.ymlの存在するディレクトリ上で行うこと
# コンテナの実行
docker-compose up -d
# コンテナの停止
docker-compose stop
# コンテナ名の確認、実行状態の確認。
docker-compose ps
# コンテナ内に入る
docker exec -it sig-beginners-pwn-public_pwn_ubuntu2204_1 /bin/bash
# または
docker-compose exec pwn_ubuntu2204 bash
# コンテナから出る
Ctrl-D
Arm Macを使っている人はこちらを利用すること。
ただし、Limaの下で動いているqemu-system-x86_64にはstackのアラインメント関連のチェックがなく、movaps命令でSIGSEGVが発生することがないことに留意。- alignment違反で落ちるように修正されているかも。
[host] brewとLimaとgitをインストール
# brewのインストール
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
# .zshrcを作っていない人は作成
touch ~/.zshrc
# .zshrcにbrewのPathを通す
# vimで~/.zshrcファイルを開く
vim ~/.zshrc
# iと打ってinsertモードに入り、以下の一行を追記
export PATH=$PATH:/opt/homebrew
# ESCでinsertモードから抜け、:wqと打って変更を保存
source ~/.zshrc
# brewが入っていることを確認
brew help
# Limaとgitのインストール
brew install lima git
# 必要なLimaの設定を持ってくる
git clone https://github.com/iwashiira/sig-beginners-pwn-public.git
cd sig-beginners-pwn-public
- Limaの起動他
# cpuやmemoryなどを指定したい人は、jammy-amd64.ymlの中の対応するエントリをnullから変更する
# ホストのディレクトリをマウントしたい人は、jammy-amd64.ymlの中のmounts部分のコメントアウトを外し、自身のProgramsの絶対pathを""内に書き込むこと。
# ubuntu22.04の仮想マシンを作成して起動(初回, 時間がかかるのでtimeoutを伸ばす)
limactl start --tty=false --timeout 60m0s jammy-amd64.yml
# 別のターミナルから、以下のコマンドを打てば、進行状況などが分かる。
tail -f -n 40 ~/.lima/jammy-amd64/serial.log
# 仮想マシンの起動
# 末尾にymlがついていないことに注意
limactl start --tty=false jammy-amd64
# 仮想マシンの一覧
limactl list
# 仮想マシンの中にはいる
limactl shell jammy-amd64
# 仮想マシンから出る
Ctrl-D
# 仮想マシンを止める
limactl stop jammy-amd64
- 色々変更したい場合はdefault.ymlを参照のこと
[ubuntu22.04]
- ホストのディレクトリをマウントしたい人は、以下のコマンドを打てば、ゲストのVM内の~/pwn/ProgramsとホストのProgramsディレクトリを繋ぐことができる。
# mount_pathにはマウントした絶対Pathを入力
ln -s mount_path ~/pwn/Programs
wget https://raw.githubusercontent.com/iwashiira/sig-beginners-pwn-public/main/command_chk.sh -O ./command_chk.sh
chmod +x ./command_chk.sh && ./command_chk.sh
# gdbを起動 (bata24/gefを使いたい場合はsudo必須)
sudo gdb --args file1 file2
# gdbを起動 (例えばchallというバイナリを動かしているプロセスにattach)
sudo gdb -p $(pidof chall)
- 拡張を使う (起動後のgdbのシェルにコマンドを入力)
- gefを使う
(gdb) gef
- pwndbgを使う
(gdb) dbg
# dockerデーモンが起動しているか確認
sudo service docker status
# 起動していない場合は
sudo service docker start
# server/challディレクトリの中の各問題のディレクトリに移動し、docker-compose up -dとコマンドを打つ
cd ./sig-beginners-pwn-public/server/chall/{chall_name}
docker compose up -d
#空いているポートを確認
lsof -i
docker-compose ps
docker ps
# サーバーに接続
nc localhost {port_number}
- 仮想環境内ではCLIでちょっとしたコードを書くなりコピペするなりしてファイルを作るので、最低限のvi系エディタの扱いは慣れておくこと。
- インサートモードから出入りするコマンドと変更を保存するorしないで閉じるコマンドさえ覚えていれば十分である。
- 何か不具合などあれば、@iwashiiraまでお知らせください。