일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- XSS
- CTF-d
- igoat
- SQL Injection
- foremost
- elasticsearch
- lord of sql injection
- InsecureBank
- 안드로이드
- otter
- Openstack
- kibana
- MFT
- Strings
- Reflected XSS
- frida
- ctf
- vulnhub
- Volatility
- Suninatas
- diva
- beebox
- Docker
- 파이썬
- NTFS
- base64
- 인시큐어뱅크
- ESXi
- logstash
- 2018
- Today
- Total
Information Security
Stack 3 본문
volatile keyword를 사용하여 int type function pointer *fp를 선언한다. char type 64 byte array buffer를 선언한다. function pointer fp(함수의 주소)에 0을 대입한다. gets() 함수를 통해 user로부터 buffer에 문자열을 입력받는다.
만일 fp의 값(함수의 주소 값)이 0이 아니면 "calling function pointer, jumping to fp"를 출력하고 fp() 함수를 실행한다. 만일 fp가 0이면 아무것도 실행하지 않는다. void의 return을 갖는 win() 함수를 선언한다. win() 함수는 "code flow successfully changed"라는 문자열을 출력한다.
"A" * 4 입력 시 아무 반응 이 없고 무작위로 대입 시 Segmentation fault 메시지가 보여지는 것을 알 수 있다.
stack 3을 gdb를 통해 분석해보았다.
RBP의 주소값을 통해서 gdb를 살펴보면 main + 27이다. main+27 : mov rdi, rax이므로 rax를 가져오는 값인 0x50과 브레이크 포인트가 걸린 fp의 0x8을 연산하면 된다. print 0x50 - 0x8은 72다.
fp의 조작을 위해 우리는 72 byte의 padding을 통해 fp에 접근할 수 있고, fp를 win()의 주소("0x0000000000401142")로 덮어 쓰면 될 것 같다.
exploit 코드를 만들었다.
코드 실행 시 "code flow successfully chagned" 메시지가 보여지는 것을 알 수 있다.