본문 바로가기

쓰기

 

안녕하세요.

 

요즘 들어 일본이 또 독도를 못살게 구는군요.

 

인터넷 상에서도 오래 전부터 독도는 일본땅 이라는 허위 정보를 장기간에 걸쳐 조금씩 조금씩

 

퍼뜨렸다고 합니다.

 

기회만 엿보며 야금야금 남의 땅 뺏어가려는 저 피곤한 소인배들을 어찌해야 한단 말입니까.

 

모든 일본게임에 훈민정음을 박아 주는 그날까지.



 

앞서 강의한 자료에 이어 계속 이어지는 AT코드 찾기 강좌입니다.

 

1편에선 실패했지만

 

이번엔 성공하니까 스크롤 끝까지 내리셔서 확인하실 필요 없습니다. (퍽퍽~!!ㅜㅜ)

 

1편에서 우리는 비록 실패했지만 다음과 같은 과정을 숙지하였습니다.

 


대사 수집
? 다음에 나올 대사의 메모리에 브레이크포인트 ? 브레이크 걸림!


 

왜 실패했나 곰곰히 생각해 보도록 하죠.

 

사실 이유랄건 없습니다.

 

당연히 먹혀야 할 방법인데 안먹힌 것 뿐이고, 우리는 계속해서 찾아나가면 됩니다.

 

앞서 발견한 함수가 대사에 접근하는 것은 맞는데, 출력하는 함수는 아닌가 봅니다.

 

하지만 대사가 있는 메모리는 이곳 하나뿐이기 때문에 어떻게든 화면에 대사를 출력하려면 대사 메모리에 접근해야 할 것입니다.

 

그러면 우리는 2가지 가정을 세울 수 있습니다.

 

1. 진짜 대사 출력 함수가 이 메모리에 다시 접근할 것이다.

 

2. 앞서 찾은 함수는 비록 출력함수는 아니었지만, 대사를 또 다른 메모리 어딘가에 복사하는 함수였다. 따라서 대사 출력 함수는 그 새로운 메모리에 접근 할 것이다.

 

여기서 후자의 경우는 생각하면 복잡해지니, 긍정적인 사고로 1번의 경우라 생각하고 진행합시다.

 

 

강좌 1편과 똑같이 올리디버거로 게임을 시작시킵시다.

 

그리고 게임이 시작되면 새 게임을 선택하여 첫 대사를 출력시킵니다.

 


강좌 1편과 같이 올리디버거로 Alt+M을 눌러 메모리 상태창으로 이동한 뒤, Ctrl+B로 다음의 대사를 찾도록 합시다.

 

아래는 강좌 1편에서 수집한 대사죠.

 

저장해 두셨으리라 믿습니다

 

안 해두셨다면 어쩔 수 없고요 ㅡ,.;;;

 

<두 번째 대사>



<
두 번째 대사의 처음 세 글자의 바이너리 값>

 


자 그럼 8E 76 82 A4 82 B1 을 찾읍시당.

 


 

바이너리 데이터를 입력하시고

 

OK를 누르시면 04B0B763 이란 메모리가 검색되었네요.

 


 
 

찾아진 메모리에 브레이크 포인트를 설정합시다.

 

혹시나 이 대사를 저장하고 있는 메모리가 더 존재하는지 확인하기 위하여, Memory Map 창에서 Ctrl+L 을 눌러 봅시다.

 

그럼 나머지 부분들을 주루룩 찾아 내려 가다가 Item not found 라고 찍히며, 창 하단에 노란색이 잠시 깜빡입니다.

 

, 이곳 외에 대사가 저장된 메모리는 존재하지 않는다는 확실한 증거죠.

 

그럼 안심하고 게임에서 다음 대사로 넘어가기 위해 클릭을 한번 해줍시다.

 

브레이크 포인트가 걸렸습니다.

 


 

앞서 1편에서 찾은 그 함수입니다.

 

별로 반갑지 않은 친구네요.

 

우리는 이 함수가 대사 출력과는 상관이 없다는 것을 1편을 통해 뼈저리게(?) 깨닳았습니다.

 

혹시 이런 질문을 하실 수도 있습니다.

 

이 함수가 직접적으로 대사를 출력하진 않지만, 여기서 다른 함수를 호출하여 거기서 대사를 출력할 수도 있는거 아닌가요?

 

, 좋은 질문입니다.

 

답은 거의 그럴 확률은 1% 미만입니다 .

 

우리는 1편에서 함수 진입점을 후킹했습니다.

 

왜 스택의 감소값까지 역추적해가며 굳이 진입점을 후킹하려 했을까요?

 

함수는 보통 아래와 같이 생겼죠.




콩 심은데 콩 나고, 팥 심은데 팥 난다는 말이 있죠.

 

콩 심는 순간 팥으로 바꿔치기 했는데 함수 중간에 콩 꽃이 피어 올라올 리 없다는 거죠.

 

물론 괴짜 프로그래머나 조잡한 컴파일러를 사용한 경우라면 예외가 있을 수 있겠지만, 이 정도 상용 게임을 출시할 만한 회사가 그런 프로그래머나 컴파일러를 쓸 리 없죠.

 

그리고 함수 진입 시의 인자 조작은 프로그램 흐름상으로도 부작용이 적습니다.

 

함수 중간에 포인터를 바꿔치기 하면, 어떤 재앙이 닥칠지 모릅니다.
 

, 다시 처음의 가정을 다시 상기시켜 봅시다.
 

이 함수가 끝나서 리턴 된 후, 어떤 코드가 또 다시 이 메모리에 접근할 것이다.

그 코드가 대사를 출력하는 코드다.

 

결론이라기 보담은 막연한 기대에 가깝지만 일단 해봅시다.

 

단순하고 쉬운거 부터 먼저 해보는게 소프트웨어 공학의 미덕입니다. ㅎㅎ

 

F9를 눌러 실행을 재개합시다.

 

.. 그런데.

 

방금 전 잡아놓은 메모리 브레이크포인트 때문에 자꾸 이 함수 안에서 브레이크가 걸리는 군요.

 

이 함수가 끝난 후를 노려야 하니, 메모리 브레이크 포인트를 풀어줍시다.

 


 

그리고 함수 끝자락에 브레이크 포인트를 걸어 놓읍시다.

 

함수 끝은 보통 RETN으로 끝이 납니다.

(어셈블러마다 RET, RETN 등 표기법은 다르지만 똑같은 겁니다.)

 



뒤의 8 stdcall 호출규약에서 스택을 +8 만큼 원상복귀 시켜준다는 의미인데,

알 필요 없으니 그냥 넘어갑시다.

 

함수 끝자락에 브레이크포인트를 걸었고, 메모리 브레이크포인트를 해제하였다면 F9를 누릅시다.

 

단숨에 RETN 코드까지 오는군요. ㅎㅎ

 

이제 이 상태에서 대사 메모리에 다시 브포를 겁시다.

(브포 : 브레이크 포인트 ㅡ,.;;;)

 

이제 어떻게 설정하는지 다 아실겁니다.

 

브포를 걸었다면 F9를 눌러 진행해 봅시다.

 

그랬더니!!

 


 

435237이란 코드가 떡밥 넘버 04B0B763을 물었다가 올리에게 낚였습니다.

 

파닥거리는 소리가 들리는듯..


CMP는 두 값을 비교하란 명령입니다. 


BYTE PTR DS:[EDI]
는 대사의 첫 번째 바이트입니다. (, 8E.)

 

CL 현재 0입니다.

 

그 다음 줄엔 JE 특정지점 이 보입니다.

 

, EDI가 가리키는 메모리의 첫 바이트와 0을 비교하여 두 개가 같다면 특정지점으로 짬프(jump)하라는 뜻입니다.

 

보통 C/C++ 같은 언어에선 문장의 끝을 0으로 표시합니다.

첫 바이트부터 0이라면 출력할 필요가 없는 빈 문장이란 뜻이겠죠.

역시나 점프하는 특정지점이란 곳이...

찾아가보니 이 함수의 거의 끝자락이군요.


오호라
냄새가 납니다. (냄새)

 

이 주소를 후킹해 보기로 합시다.

 

그런데 여기서 대사 포인터가 저장되어 있는 EDI의 값은
 
이 함수의 어디서 세팅 되었을까요?

 

함수 내에서 코드를 거슬러 올라가다 보면 아악~~!

 

눈알이 빠질 것 같습니다.

 

겨우 찾아낸 곳이

 


 

함수 진입점 부근이군요.

 

ESP 58, 4, 4, 4, 4 이렇게 감소되었으니 16진수로 총 68이 감소되었습니다.

 

따라서 저기 보이는 [ESP+6C]는 함수 진입점에서는 [ESP+4] 입니다.

 

[ESP+4]는 함수 호출시 첫 번째 인자.

 

여기서 팁을 알려 드리겠습니다.


꼭 위처럼 거꾸로 계산하지 않더라도  콜 스택 이란것을 보면 쉽게 알 수 있습니다.


Alt+K
를 누르시면 콜 스택 창이 뜹니다.

 


 

Arg1 에 대사 메모리 주소가 넘어오고 있군요.

 

콜 스택이란 어떤 함수가 어떤 함수를 호출했고, 호출된 함수가 또 어떤 함수를 호출했고 그런 정보를 보여줍니다.

 

따라서 위의 작품을 설명드리자면

 

436130 함수 내에서 435130 함수를 호출했는데 그 인자로 04B0B763, 0013FE04를 넣었다.

 

라는 겁니다.


하지만 불행히도 콜스택이 항상 이렇게 착한 모습으로 나타나진 않습니다.
 

, 이제 후킹할 함수 지점(435130)도 알았겠다, 그 인자([ESP+4])도 알아냈으니 AT코드에 적용해 봅시다.

 

우선 게임을 다시 실행시킨 후 AT를 먹입니다.




후킹주소 추가를 눌러 우리가 찾은 함수 진입점 435130을 적으시고

 

메모리는 [ESP+0x4]를 선택합니다.

 



그리고 메모리 바꿔치기 방식을 선택해 주세요.

 

! 한글이 출력되나 볼까요~

 

 


!! 이게 모얌~!!

 

뭔가 달라진 것 같은데 네모나라 언어가 출현하네요.

 

SHIFT-JIS 코드 범위에 들어가지 않는 문자는 이런 식으로 필터링 되나 봅니다.

 

당황하지 마시고 옵션에서 한글을 일본 문자셋으로 변환을 체크해 줍시다.

 

짜잔~

 


 

한글 대사가 나옵니다.

 

이름은 여전히 번역이 안되는군요.

 

이름은 다음 강좌에서 찾아보도록 하겠습니다.

 

그럼 3편에서 계속.

 

 

Hide_D

2008.05.22
23:48:03
문장 HEX 변환기
클립보드 후커 제작자님 홈피에 있는 녀석

EditPlus -> UltraEdit 조합보다 한결 편합니다.

안돌아간다면
JRE6을 설치해 주세요

라파에

2008.05.23
11:12:49
헤.. 오늘에서야 강좌를 보게 됏네요

저번에 덧글로 부탁 드렷던 강좌인데 .. 이리 올려주시니 감사할 따름 ㅜㅜ

3편도 기대하며 보겠습니다!

플랑베르

2008.07.21
21:37:54

ㅎ... 고3 때 교과서를 읽는 것보다 더 열심히 읽은 것 같은데 머리에 하나도 안들어 오네요 ㅡㅡ;;

으윽.....내가 이렇게 돌머리 였더가 ㅡ0ㅡ;;;

같이갈래?

2008.07.30
10:42:06

존경합니다... 이 말밖에 할말이 없군요 ㅋㅋ

아자토스

2008.10.14
22:33:51
... 어려워..

마이아크

2008.11.10
05:49:29
죽겄다....머리 아파서

Hide_D

2008.11.23
11:14:50
감사합니다~

이름까지 같이 찾는데 성공했어요!

꿈꾸는아이

2008.12.10
07:50:37
저것들은다 어느나라 말일까???
갑자기 외국에온느낌이...

HaruKaze

2008.12.16
16:50:32
메뉴얼 잘 보았습니다. 많은 도움이 되었습니다.

감사합니다...(_ _)

zpdls

2009.02.13
11:16:08
모든 일본게임에 훈민정음을 박아 주는 그날까지.
명대사네요 ㅎㅎ

태상호이

2009.04.02
18:28:16
모든 일본게임에 훈민정음을 하루 빨리 박는 그날이 왔으면 좋겠네요 ^ㅡ^

다커

2009.04.03
00:04:02
메모리 멥에서 메모리가 더있는지 확인할떄 컨트럴 엘 눌렀을때 메모리가 더있는데 이것은 어떻게 하나요?
그 다른것 메모리 브레이크 포인트하면 전에 했던것까지 메모리 브레이크가 되버리는데 ; ㅁㅁ
이거하나가 문제군요 흠....

루시퍼

2010.01.05
01:47:44
생각보다 많이 어렵네요 ㅜㅡ
어셈쪽은 처음이라 뭔말인지.... 그래도 한번 도전 해봐야겠어요 ㅎㅎ
좋은 강의 감사합니다.^^
List of Articles
번호 제목 글쓴이 조회 수sort 추천 수 날짜 최근 수정일
공지 아랄트랜스로 게임하기 앞서 기본 셋팅 확인하기! [4] file TwoComet 40499   2012-08-30 2014-02-26 20:12
공지 아랄트랜스 - 초보자 가이드 [94] file Hide_D 319327   2008-07-16 2015-02-27 18:02
공지 모든 플러그인, 필터 안내 ('09.03.13) [20] Hide_D 191382   2008-10-31 2009-03-13 23:48
공지 아랄트랜스 0.2 - 초보자 가이드 [109] file 아랄 505851   2008-07-16 2013-12-31 09:32
77 시작메뉴 경로 오류로 인한 프로그램 설치 불가 해결 방법 [4] file TheMan 9383   2009-09-06 2009-11-28 03:55
 
76 코드파인드를 위한 기초 지식(3) [4] file G2m2000 9378   2011-07-13 2011-12-07 16:13
 
75 비스타에서 아랄트랜스로 후킹시 게임이 사라질때 [8] file my Vagina 9350   2008-10-06 2009-01-06 01:23
 
74 커스텀딕이라, 이름 사전 정도는 나도 만든다고! [6] file 키리아스 9319   2010-10-31 2012-11-09 00:40
 
73 진 연희무쌍 아랄트랜스 튕길시 대책 또다른 방법 [3] file 까나리 9053   2009-09-21 2009-10-26 17:21
 
72 아랄트랜스로 일본어 원문을 볼 수 없나요? file 처음처럼만 8741   2009-01-01 2009-01-01 14:40
 
71 息子の友達に犯されて(아들의 친구에게 범해져) 코드 적용하는 법 [2] file 암흑마제 8724   2009-01-15 2009-01-15 15:03
 
70 꿈의 장인의 이미지 강좌 [2] - 포토샵으로 배경 선 따기. [10] file 유메 8532   2009-01-12 2010-04-03 11:55
 
69 랴겜 설치시 안되는 게임 꼼수로 설치하기 .. [6] file 월희 8474   2009-01-12 2010-04-03 18:33
 
68 어플로도 실행안되는 미연게임들 있잔아요... [16] file 대돌이 8442   2009-01-10 2009-07-15 12:56
 
67 간단하게 적어두는 아랄트랜스 사용 방법! [1] Hide_D 8383   2011-02-19 2011-03-08 19:27
이미지로 된 것에 비해서 불친절하지만 약간 다른 내용도 있고 해서 쓸만할겁니다 ㅇㅇ 0-1. AppLocale 설치 0-2. ezTransXP 설치 0-3. 이지트랜스 딱 한번만 실행하고 '웹 프록시 기능'을 끄고 종료 1. 게임을 실행(주로 AppLocale로 실행함) 2. 아랄트랜스 ...  
66 기리기리엔진에 대해 여러가지 [3] 고토회복 8358   2012-06-25 2015-12-06 04:09
1. 무료엔진이라는 겁니다 이걸 왜 이야기 하냐 하면 그러므로 버전별로 안전판 원본이 있어요 도대체 무슨 이야기야? 하는 분들 많을듯... 어느 회사가 기리기리로 게임을 제작합니다.. 버전별로 전부 툴이 있지요 ^^ 그개 다 공개고 자 여기에서 어느 회사가...  
65 아랄 컨텍스트 메뉴 지우는 방법 [4] 평군 8149   2009-11-16 2009-12-03 19:14
윈 7 에서는 '처음처럼만'님이 배포한 아랄 컨텍스트 0.9 확장버전이 제대로 설치되지 않습니다. 오히려 이상한 목록이 생겨서 오른쪽메뉴가 더러워지죠... Hide_D님의 버전은 잘 돌아가는 것을 확인했습니다. 히데님의 버전은 제거파일도 있으니 참 쉽죠 =ㅂ...  
64 밑의 글의 보충 설명이랄까요 [2] 불협 8099   2010-06-24 2010-09-26 09:43
저도 프로그래밍은 조금 배웠지만, 디버깅에 대해선 아는게 없어서 밑의 글을 읽고 도움이 참 되었습니다. 다만, 프로그래밍 경험이 없는 분들의 입장에선 조금 이해하기 어렵단 생각이 드네요.ㅎ 특히 첫번째 강좌와 두번째 강좌의 레벨차이가 꽤 난다는 생각...  
63 글씨가 누워져서 뜰 때 [1] file 처음처럼만 8003   2008-12-12 2009-11-03 15:02
 
62 코드를 찾아 여행하는 히치하이커를 위한 작은 팁 [1] 어린나무 7906   2013-01-22 2014-09-26 16:06
의지의 한국인어쩌면 이글은 올라가자마자 짤릴거 같지만 일단은 글을 써보도록 하겠습니다. 일단 불순한의도로 가입을 하였고 많은 능력자분들의 도움으로 게임을 즐겨왔습니다.(하드에 미연시나 야동, 기타 성인물이 없으신 분만 저를 욕하세요) 아무튼 그중...  
61 SiglusEngine 복불복 막장드립 [5] file 두병더더 7885   2012-08-12 2015-08-11 16:01
 
60 꽃과 뱀 진행 도중 튕길 때 [4] 베트맨바이러스 7857   2009-02-02 2010-11-26 02:45
뒤 늦게 솔로의 필수품 아스트랄(?) 세계에 입문하여 첫 작품으로 꽃과 뱀이라는 것을 채택 실행하게 되었는데... 코드 찾으면서 댓글을 보니 몇페이지 안가서 오류 나고 진행이 안된다는 얘기가 있었는데 설마 나는 아니겠지..하고 실행해봤는데 왠걸.. 나도 ...  
59 준한글화 게임 플레이시 번역 이상하게 나오시는 분들 [2] 난오타쿠가아니야 7805   2008-11-24 2008-11-25 17:57
칭송받는자를 클리어하고 레콘키스타를 플레이중인데 이상하게 아랄이 커스텀 스크립트를 전부 불러들이지 않고 부분부분 아랄이 직접 번역해 문장이 요상꼴랑하게 출력되더군요-_-;; 역시나 질답게시판에서 검색해보았으나 저와 같은 증상을 겪으신 분들 모두...  
58 기리기리 데이터 추출 [1] file 두병더더 7759   2012-12-06 2012-12-13 11:50