Wargame
-
lvl 02Wargame/CodeEngn Basic RCE 2018. 12. 9. 19:39
문제 패스워드로 인증하는 실행파일이 손상되어 실행이 안되는 문제가 생겼다. 패스워드가 무엇인지 분석하시오 풀이 → 프로그램을 실행한다. 다음과 같은 에러가 나타난다. → 실행되지 않는다. 그렇다면 IDA로 열어본다. → PE 실행파일로 인식하지 못한다. 그렇다면, 실행파일 구조가 깨져있는 것을 예상해볼 수 있으며, 문제에서도 실행파일이 손상되었다고 제시한 것을 참고한다. → 따라서, 실행파일 구조를 살펴보기 위해, [Binary file] 메뉴를 선택해서 로드한다. → MZ 시그니처는 확인할 수 있으나, PE 시그니처를 찾을 수 없다. → PE시그니처 값인 (50 45 00 00)이 없는 것을 확인했고, PE 헤더부분이 일정부분 없어진 것으로 추측할 수 있다. → 패스워드 값을 찾기 위해, 나머지 바이너..
-
lvl 01Wargame/CodeEngn Basic RCE 2018. 12. 9. 18:11
문제 HDD를 CD-Rom으로 인식시키기 위해서는 GetDriveTypeA의 리턴값이 무엇이 되어야 하는가 풀이 → 프로그램을 실행한다. → 음.. CD-ROM Drive가 아니라고 Alert 메시지가 나타난다. → 디스어셈블을 해보았다. 프로그램 구조가 대충 파악된다. → GetDriveTypeA 함수를 실행한 후, eax 레지스터와 esi 레지스터를 비교한 결과를 통해 성공 유무를 파악한다. → 적당한 곳에 bp를 찍고 디버깅한다. → GetDriveTypeA 함수를 실행한 직후, eax 레지스터의 값이 "3"임이 확인된다. → eax 레지스터는 값이 1이고, esi 레지스터는 401003인 것을 알 수 있다. → 따라서, cmp eax, esi 코드가 실행되기 전, esi 레지스터를 강제로 1로 맞..