질문/답변 게시판을 1년에 하나씩 새로 추가하는 것 같습니다. ^^

많은 분들께서 방문해주시고 질문/답변을 남겨주셔서 정말 감사합니다.

* 되도록 이면 '비밀 댓글' 보다는 '일반 댓글'을 이용해서 질문해 주시기 바랍니다. 비슷한 궁금증을 가지신 분들께도 널리 공유되면 좋겠습니다.

* 예전 질문/답변 코너 링크입니다. (원하시는 내용이 있는지 검색해 보세요~)
=======================================================

리버스 엔지니어링 분야에 대해 질문이 있으시면 아래의 댓글로 올려주세요. 역시 댓글로 답변을 올려드리겠습니다. 공개하기 어려운 내용은 '비밀글' 에 체크해주세요.

"비도덕적, 불법적" 인 내용은 답변 드릴 수 없음을 이해해 주시기 바랍니다.


댓글, 방명록, 이메일 등으로 많은 분들께서 여러 가지 질문들을 해주십니다. 
그중에 정말 좋은 질문들이 많아서 여러분들과 공유하면 좋겠다고 생각하였습니다.

이제부터 저에게 들어오는 모든 질문과 답변들을 이곳으로 모을 것입니다.
앞으로 질문과 답변은 이곳에서 해주세요~

질문에 대한 답변은 저 뿐만 아니라 제 블로그에 오시는 모든 분들께서 하실 수 있습니다.
문제 해결을 위한 방법은 다양합니다. 저 말고도 다른 분들의 답변은 언제나 환영입니다.

"질문은 좋은 것 입니다. 많이 해주세요. ^^ "

* 댓글로 질문하기 어려운 내용들(긴내용, 첨부파일 등)은 제 이메일(reversecore@gmail.com)로 문의해 주세요.

* 제가 사용하는 GMail 은 PE 파일을 첨부하면 전송 거부를 합니다. (압축을 시켜도 그걸 열어서 확인하지요.)
   => 실행 파일을 첨부해서 보내실때는 확장자를 exex, dllx, zipx 등으로 변경해서 보내주세요.

* 댓글이 너무 많이 달리면 제가 질문/답변 빈 포스트를 또 올릴 겁니다. 그쪽으로 계속 질문 댓글 달아주시면 됩니다.

감사합니다.


ReverseCore

'q&a' 카테고리의 다른 글

질문/답변 코너입니다. (3)  (394) 2011.04.13
질문/답변 코너입니다. (2)  (233) 2010.01.28
질문/답변 코너입니다.  (295) 2009.09.21
    이전 댓글 더보기
  1. yO Kang 2014.03.27 15:29 신고 댓글주소 | 수정 | 삭제 | 댓글

    PE FILE에서 IAT 부분에 대해서 질문좀 할게요.
    IAT에서 나오는 IMAGE_IMPORT_DESCRIPTOR 구조체에서 OriginalFirstThunk 멤버 변수와
    FirstThunk 멤버 변수는 각 각 INT, IAT를 가리키고, 그 INT와 IAT는 IMAGE_THUNK_DATA 구조체 배열로 구성되어 있잔아요.

    제가 궁금한 부분은 이 IMAGE_THUNK_DATA 구조체는 유니온으로 멤버변수들이 선언되어 있어서
    상황에 따라 사용하는 멤버변수가 다르다고 알고있는데요. AddressOfData 변수가 사용될 때
    AddressOfData가 IMAGE__IMPORT_BY_NAME 구조체를 가리키는 포인터로 사용된다고 하던데,
    AddressOfData 변수를 사용하지 않을 시엔 IMAGE_IMPORT_BY_NAME 구조체를 사용하지 않는건가요??? IAT 자료들을 여러개 찾아봤는데 모식도나 구조도 같은거 보니까, 일반적으로 모두 IMAGE_THUNK_DATA 구조체에서 IMAGE_IMPORT_BY_NAME 구조체를 가리키게 되있더라구요. 당연하다는 듯이... 이부분이 지금 무척 궁금합니다. 다른 변수를 사용할때는 어떻게 되는것인가에 대해서.

  2. hoho313 2014.06.10 20:46 신고 댓글주소 | 수정 | 삭제 | 댓글

    안녕하세요 ㅎㅎ

    공부하던 중에 여쭤볼게 생겨서요~

    제가 이해를 못한건지 아니면 그림이 잘못 캡쳐가 된것인지
    그림 18.24의 내용이 잘린거 같은데 맞나용??

    그리고 146페이지에 IMAGE_DOS_HEADER 구조채의 크기는 40 이라고 나와있는데 64아닌가용??

    그럼 즐거운 하루 보내세요 ^0^***

    • reversecore 2014.06.14 22:36 신고 댓글주소 | 수정 | 삭제

      안녕하세요.

      3쇄의 18.24 그림은 잘 못 되었습니다. 아래 errata 페이지에 제대로된 이미지를 올렸습니다.
      http://reversecore.com/105

      16진수 40 => 10진수 64 맞습니다~
      리버싱에서는 16진수 표현이 더 자연스러워서 그렇게 표시하였습니다.

      감사합니다.

  3. shiri 2014.06.25 12:34 신고 댓글주소 | 수정 | 삭제 | 댓글

    안녕하세요

    Hello World! 리버싱을 해보려고 Ollydbg 110으로 실행을 했는데 CALL 0040270C는 안보이고

    774A01B8 895C24 08 MOV DWORD PTR SS:[ESP+8],EBX 이런게 먼저 나오네요...

    200버전으로 다시 실행해도 책에 있는 것처럼 나오지 않아서 책 따라하기가 힘들어요

    제 운영체제가 64비트인데 혹시 이것 때문인가요?

  4. ㅇㅇ 2014.07.08 13:26 신고 댓글주소 | 수정 | 삭제 | 댓글

    p.165 Q3문제에서
    rva를 raw로 변환했는데, 그 값이 초과되어 rva의 섹션과 raw의 섹션이 다르게 나왔고
    그 이유가 VirtualSize값이 SizeOfRawData보다 크기 때문이다.
    라고 나와있는데요.
    이거 잘못된 것 아닌가요
    위의 섹션이 다르게 나오는 경우는
    VirtualSize > SizeOfRawData 가 클 때가 아니라
    RVA - VA > SizeOfRawData일 때 아닌가요?

    반례를 들면, data섹션의 파일 옵셋이 0~1000, VA가 0~1100이고
    RVA는 100이라고 가정했을 때
    위의 설명대로라면 VirtualSize(1100) > SizeOfRawData(1000) 이므로 RVA->RAW 변환했을 때 섹션이 다르게 나와야 하지만
    RVA-VA=100 RAW=100, RVA와 RAW의 섹션은 data로 동일합니다.

  5. ㅇㅇ 2014.07.08 13:26 신고 댓글주소 | 수정 | 삭제 | 댓글

    p.165 Q3문제에서
    rva를 raw로 변환했는데, 그 값이 초과되어 rva의 섹션과 raw의 섹션이 다르게 나왔고
    그 이유가 VirtualSize값이 SizeOfRawData보다 크기 때문이다.
    라고 나와있는데요.
    이거 잘못된 것 아닌가요
    위의 섹션이 다르게 나오는 경우는
    VirtualSize > SizeOfRawData 가 클 때가 아니라
    RVA - VA > SizeOfRawData일 때 아닌가요?

    반례를 들면, data섹션의 파일 옵셋이 0~1000, VA가 0~1100이고
    RVA는 100이라고 가정했을 때
    위의 설명대로라면 VirtualSize(1100) > SizeOfRawData(1000) 이므로 RVA->RAW 변환했을 때 섹션이 다르게 나와야 하지만
    RVA-VA=100 RAW=100, RVA와 RAW의 섹션은 data로 동일합니다.

  6. ssss 2014.07.12 21:27 신고 댓글주소 | 수정 | 삭제 | 댓글

    리틀엔디언 질문이요.
    책에보면 메모리 값을 읽을 때
    어떤건 리틀엔디언 적용해서 거꾸로 읽고
    어떤건 적용안하고 메모리 값 그대로 읽고
    하던데 왜이러는건가요?

    가령
    파일을 hxd로 열었을 때
    0x00 10 00
    0x02 20 00
    이고
    0x00은 구조체 멤버1의 값
    0x02는 구조체멈버2의 값
    라고 했을때
    책에서
    이 구조체멤버의 값을 읽어줄때
    구조체멈버1: 1000
    구조체멤버2: 0020
    이런식으로 하나는 리틀엔디언 적용안하고
    하나는 적용하고
    이러는데 왜 이러는건가요??

  7. battlecoalla 2014.07.19 01:07 신고 댓글주소 | 수정 | 삭제 | 댓글

    작가님 책 잘 보고있습니다.
    다름이 아니라, 제가 공부를 하는데 지금 사용하는 운영체제가 우분투입니다..
    혹 책보면서 공부하기 좋은 툴이 있는지요? 찾아봐도 우분투쪽은 잘 안나오네요 ㅠㅠ

  8. eeee 2014.07.20 08:35 신고 댓글주소 | 수정 | 삭제 | 댓글

    페이지 225 PE파일 재배치원리 설명 부분을 보면 "TypeOffset 값이 0이 되면 하나의 IMAGE_BASE_RELOCATION구조체가 끝납니다"라는 문장이 있는데
    이 문장의 뜻이 IMAGE_BASE_RELOCATION구조체의 마지막 TypeOffset 멤버의 값이 0이라는 얘기인가요?

  9. RedCode 2014.07.22 14:19 신고 댓글주소 | 수정 | 삭제 | 댓글

    2.2.4 세션 20470C 함수따라가기 에서 막히네여

    제 Pc는 Win7 32bit 입니다.

    제Pc에서보면 시작번지가 00426479 로 시작해서 쭈욱 시퀀스 생기네여

    아무리 봐도 40270C 가없네여

  10. Say-Y 2014.09.01 01:13 신고 댓글주소 | 수정 | 삭제 | 댓글

    책204쪽 notepad_upx.exe 의 ep code 부분에
    예/아니오 중에 아무거나 선택해서 넘어가면 그림 15.3과 같이 upx ep 코드가 나타납니다.
    라고 되있는데 바로 notepad.exe 의 ep코드와 같은 부분으로 넘어갑니다. 물론 0101532f의 upx ep코드가 있긴 합니다만. ollydbg 신버젼2.0인가 를 사용해서 그런가요? 그렇다면 upx ep에서 시작하려면 어떻게 해야하나요?

  11. Seo 2015.01.07 14:23 신고 댓글주소 | 수정 | 삭제 | 댓글

    p76 ~ 77에 있는 StackFrame에 대해 질문이 있습니다.
    StackFrame.cpp를 비주얼스튜디오를 이용해서 exe 파일을 생성했습니다.
    (최적화 옵션을 off 했습니다.)

    올리디버거로 StackFrame.exe 파일을 열고, 401000 주소로 이동하려고 했습니다.
    그런데 401000 주소는 보이지 않아요.
    제 컴퓨터에서는 00401000 주소가 아니라 002C1000으로 나타납니다.

    어셈블리 내용들은 교재와 똑같이 나오는데,
    주소가 다르게 출력되는 상황이에요.
    00401000으로 출력되게 하려면 어찌해야 하는지 궁금합니다!!

  12. yOkang 2015.01.13 16:36 신고 댓글주소 | 수정 | 삭제 | 댓글

    DLL 인젝션, 처음 부분인 메시지 후킹 실습 관련 질문좀 드릴게요.
    HookMain.cpp / KeyHook.dll 이용해서 , 메모장 열어서 키보드 입력시
    입력은 안먹히긴하는데, HookMain.exe 가 뻗어버리고, 내용상으로는 노트패드명
    확인해서 노트패드인 경우에만 입력을 후킹하는걸로 되어있는데,
    다른 프로그램에서 키보드 입력을 해도 먹히지 않으면서 뻗어버리네요.
    그리고, 프로세스 익스플로러에서 dll 인젝션됬는지 확인하려고 계속 체킹하는데.
    노트패드에 KeyHook.dll이 인젝션되지 않은건지 됬는데 뻗어서 안뜨는건지...
    확인이 안되네요. 뭐가 문제일까요?

  13. 쉬리 2015.02.08 23:15 신고 댓글주소 | 수정 | 삭제 | 댓글

    안녕하세요. 현재 코드 인젝션(27장)을 공부하고 있습니다. InjectionCode() 함수에서
    dwSize = (DWORD)InjectionCode - (DWORD)ThreadProc; 처럼 함수의 크기를 구하는 것이
    MS Visual C++에서 사용된다면 다른 컴파일러에서는 어떠한 방법으로 함수의 크기를 구하는지
    알고싶습니다. 답변주시면 감사하겠습니다.

  14. 이경묵 2015.06.30 12:38 댓글주소 | 수정 | 삭제 | 댓글

    관리자의 승인을 기다리고 있는 댓글입니다

  15. 이시 2015.07.18 03:38 댓글주소 | 수정 | 삭제 | 댓글

    관리자의 승인을 기다리고 있는 댓글입니다

  16. 나작소 2015.08.04 16:34 댓글주소 | 수정 | 삭제 | 댓글

    관리자의 승인을 기다리고 있는 댓글입니다

  17. 엄기영 2015.09.23 19:52 댓글주소 | 수정 | 삭제 | 댓글

    관리자의 승인을 기다리고 있는 댓글입니다

  18. 엄기영 2015.09.23 23:32 댓글주소 | 수정 | 삭제 | 댓글

    관리자의 승인을 기다리고 있는 댓글입니다

  19. 로기리 2015.11.07 07:57 댓글주소 | 수정 | 삭제 | 댓글

    관리자의 승인을 기다리고 있는 댓글입니다

  20. 151127 2015.11.28 04:54 댓글주소 | 수정 | 삭제 | 댓글

    관리자의 승인을 기다리고 있는 댓글입니다





티스토리 툴바