Hacking/Pwnable
[Pwnable] 포맷 스트링 버그 (Format String Bug)
미친해커
2021. 6. 17. 00:23
반응형
Format String이란 printf 계열의 함수를 이용할때 사용하는 특수한 형식의 문자열이다. 예를 들어 다음과 같은 C언어 코드가 있다고 하자
#include <stdio.h>
int main(int argc, char *argv[])
{
char text[] = "Hello World!";
int i = 30;
long h = 0xDEADBEEF;
printf("%s %d %x\n", text, i, h);
}
printf 가변인자를 받고 서식문자에 맞춰서 인자로 들어온 데이터를 출력해준다.
출력 결과를 보다시피 '문자열 정수 16진수' 형태로 출력이 되었다. 각각 %s는 문자열(String), %d는 정수(Decimal), %x는 (heXadecimal) 를 나타낸다. 그렇다면 이것이 왜 문제일까? printf 함수가 출력되기 전 스택상태를 확인해보자
(32bit 기준) 스택은 다음과 같이 생성된다. 마지막 인자부터 순서대로 스택에 쌓고 함수를 호출한다. 그렇게 되면 printf 함수는 첫번째 인자로 들어온 문지열을 분석한다. 서식문자를 보고 그 위치에 맞게 인자로 들어온 변수를 출력하게 된다.
만약 포맷 스트링만 인자로 주고 다음 인자를 주지 않으면 어떻게 될까?
위와 같이 접근하여 printf를 호출하기 전 함수의 스택의 데이터를 출력시킬 수 있다. 즉 %n을 사용한 덮어쓰기 또는 메모리 Leak이 가능하다.
반응형