data:image/s3,"s3://crabby-images/e6cc5/e6cc50836ed04d33ca5043309aae9a35cde5a453" alt=""
Level19
level19의 계정으로 접속한 후, hint를 확인해보면 다음과 같습니다.
data:image/s3,"s3://crabby-images/c0f9d/c0f9de1359e7db40ce4fcb31a317c662e62f75c7" alt=""
입력받는 문자열의 길이를 체크하지 않는 gets함수이기 때문에, BOF취약점이 존재합니다. 코드 분석을위해 gdb를 이용하였습니다.
data:image/s3,"s3://crabby-images/754b7/754b7e797a32918582fcd8210c11344304dab671" alt=""
메모리 공간으로 할당된 크기는 40byte입니다. 만약 이 정보들을 가지고 BOF공격을 시도하게 되면, level20의 권한이 아닌 level19의 권한으로 shell이 실행됩니다.
level20권한의 shell을 실행시키기 위해 setreuid(3100,3100)과 system("/bin/sh")를 실행시킬 것입니다.이를 위해 Chaining RTL을 이용하였습니다. Chaining RTL을 위해 스택을 도식화해보면 다음과 같습니다.
data:image/s3,"s3://crabby-images/a6378/a6378edcc648018fd8958bd46f4b91120028dab6" alt=""
먼저 setreuid() 와 system()의 주소를 찾았습니다.
data:image/s3,"s3://crabby-images/768ec/768ecda3032275a5a0e16548f36729e8bbce929e" alt=""
pop -pop - ret 을 찾기 위해 다음과 같이 objdump를 이용하였습니다.
data:image/s3,"s3://crabby-images/aba44/aba44030ba9a0028b7d28ed0df52f892964f2e99" alt=""
마지막으로 /bin/sh의 주소를 이용하기 위해 level11에서 사용했던 코드를 이용했습니다.
data:image/s3,"s3://crabby-images/7df66/7df6632cc8e9a95af46f8819a5e014ba20e708f1" alt=""
위 코드를 컴파일한 후, 실행하면 다음과 같이 /bin/sh가 위치한 주소를 알 수 있습니다.
data:image/s3,"s3://crabby-images/2f7d0/2f7d0a04b3a13ba3efc2f7a070c97099780caf48" alt=""
필요한 값들을 모두 알았으니, 위에 도식화한 그림순으로 값을 대입하여 payload를 구성하여 입력하였습니다.
data:image/s3,"s3://crabby-images/4dcba/4dcba66476bbffa8329cb565a98e2486155b1b56" alt=""
No comments:
Post a Comment