overflow로 stack retrun address 바꾸는 방법?

dalili의 이미지

#include
#include
#include

void func1();
void func2();

int main(int argc, char **argv)
{
func1();
}

void func1()
{
char str[4];

// overflow code
}

void func2()
{
printf("call func2\n");
}

실행시 func2 호출되게 stack의 return address 를 바꿔 보려고 하거든요
해봤는데 잘 안되네요
어떻게 해야 하나요?

익명 사용자의 이미지

쉽습니다.

void func1()
{
func2();
}
익명 사용자의 이미지

func2 주소를 얻어내시구요. func1() 에서 str 크기인 4byte+sfp 하면 return address 주소가 계산되는데요 그 주소에다가 func2() 넣어주면 실행하면 func2가 호출되긴 할거에요.

근데 일단 이거 요즘 리눅스에서 하시려면 스택가드나 , 랜덤 스택 따위 옵션 다 끄고하셔야지 안그러면 안됩니다.

이건 혼자서 그냥 캐삽질을 엄청 하면 됩니다.

익명 사용자의 이미지

이론은 대충 알고 있는데 삽질 많이 해봤는데 잘 안되더라고요
옵션 끄고 다시 삽질 해봐야겠네요
감사합니다

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.