Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 5개 있습니다.)
디버깅 기술: 53. windbg - 덤프 파일로부터 네이티브 DLL을 추출하는 방법
; https://www.sysnet.pe.kr/2/0/1386

디버깅 기술: 79. windbg - 풀 덤프 파일로부터 .NET DLL을 추출/저장하는 방법
; https://www.sysnet.pe.kr/2/0/10943

디버깅 기술: 94. windbg - 풀 덤프에 포함된 모든 모듈을 파일로 저장하는 방법
; https://www.sysnet.pe.kr/2/0/11280

디버깅 기술: 117. windbg - 덤프 파일로부터 추출한 DLL을 참조하는 방법
; https://www.sysnet.pe.kr/2/0/11639

.NET Framework: 2059. ClrMD를 이용해 윈도우 환경의 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
; https://www.sysnet.pe.kr/2/0/13144




windbg - 덤프 파일로부터 네이티브 DLL을 추출하는 방법

예전에, 덤프 파일로부터 .NET DLL을 추출하는 방법(!savemodule [주소] [저장파일])을 설명했었는데요.

닷넷 응용 프로그램에서 특정 예외가 발생했을 때 풀 덤프받는 방법
; https://www.sysnet.pe.kr/2/0/1376

검색해 보니 네이티브 DLL도 추출할 수가 있군요. ^^

Special Command - Saving Modules Using .writemem
; http://blogs.msdn.com/b/debuggingtoolbox/archive/2009/09/23/special-command-saving-modules-using-writemem.aspx

어디 실습을 한번 해볼까요?

0:000> lm
start             end                 module name
...[생략]...           
00000000`00d60000 00000000`00daa000   XAPI       (deferred)             
...[생략]...           
000007fe`ffd10000 000007fe`ffd5d000   ws2_32     (deferred)             

Unloaded modules:
00000000`75620000 00000000`756e9000   MSVCR80.dll
...[생략]...           
00000000`6e660000 00000000`6e680000   ATL80.DLL
00000000`00ff0000 00000000`0103a000   XAPI.dll

lm 명령을 내리는 경우 마지막에 "Unloaded modules" 목록이 나오는데요. 그 부분은 무시해야 합니다. 거기의 주소는 사용하면 안 되고, 그 윗부분에 로드되어 있는 목록의 주소를 writemem 명령어의 인자로 전달합니다. 예를 들어, 위의 결과에서 XAPI.dll 을 저장하고 싶다면 다음과 같이 명령어를 실행합니다.

0:000> .writemem C:\temp\dll\XAPI.dll 0000000000d60000 (0000000000daa000 - 0x1)
Writing 4a000 bytes............

또는, 길이를 "L" 인자와 함께 지정해도 됩니다.

0:000> ? 0000000000daa000 -0000000000d60000
Evaluate expression: 303104 = 00000000`0004a000

0:000> .writemem C:\temp\dll\XAPI.dll 00000000`00d60000 L 0004a000
Writing 4a000 bytes............

물론, 메모리에 올라와 있는 것이기 때문에 파일로 존재할 때의 PE 포맷과는 다릅니다. 그래서, 보통은 DLL 파일을 저장하는 용도 보다는 디버깅하다가 포인터 변수를 추적하면서 대량의 바이너리 데이터를 분석할 필요가 있을 때 유용할 수 있습니다. ^^

참고로, 위와 같이 저장한 DLL이 .NET DLL이라면 Decompiler 도구 등을 이용해 역어셈블하는 것도 가능합니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 7/13/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2015-08-20 01시10분
정성태

... 106  107  108  109  110  111  112  113  114  115  116  117  118  119  [120]  ...
NoWriterDateCnt.TitleFile(s)
11016정성태8/7/201628009개발 환경 구성: 291. Windows Server Containers 소개
11015정성태8/7/201626686오류 유형: 348. Windows Server 2016 TP5에서 Windows Containers의 docker run 실행 시 encountered an error during Start failed in Win32
11014정성태8/6/201627069오류 유형: 347. Hyper-V Virtual Machine Management service Account does not have permission to open attachment
11013정성태8/6/201638331개발 환경 구성: 290. Windows 10에서 경험해 보는 Windows Containers와 docker [4]
11012정성태8/6/201628478오류 유형: 346. Windows 10에서 Windows Containers의 docker run 실행 시 encountered an error during CreateContainer failed in Win32 발생
11011정성태8/6/201629680기타: 59. outlook.live.com 메일 서비스의 아웃룩 POP3 설정하는 방법
11010정성태8/6/201626228기타: 58. Outlook에 설정한 SMTP/POP3(예:천리안 메일) 계정 암호를 잊어버린 경우
11009정성태8/3/201631226개발 환경 구성: 289. 2016-08-02부터 시작된 윈도우 10 1주년 업데이트에서 Bash Shell 사용 [8]
11008정성태8/1/201625929오류 유형: 345. 2의 30승 이상의 원소를 갖는 경우 버그가 발생하는 이진 검색(Binary Search) 코드
11007정성태8/1/201627518오류 유형: 344. RDP ActiveX 컨트롤로 특정 PC에 연결할 수 없을 때, 오류 상황을 해결하기 위한 팁파일 다운로드1
11006정성태7/22/201630911개발 환경 구성: 288. SSL 인증서를 Azure Cloud Service에 적용하는 방법
11005정성태7/22/201629674개발 환경 구성: 287. Let's Encrypt 인증서 업데이트 주기: 90일
11004정성태7/22/201623921오류 유형: 343. Invalid service definition or service configuration. Please see the Error List for more details.
11003정성태7/20/201631776VS.NET IDE: 110. Visual Studio 2015에서 .NET Core 응용 프로그램 개발 [1]
11002정성태7/20/201625066개발 환경 구성: 286. Microsoft Azure 서비스의 구독은 반드시 IE로!
11001정성태7/19/201636344.NET Framework: 599. .NET Core/SDK 설치 및 기본 사용법 [6]
11000정성태7/16/201624906오류 유형: 342. Microsoft Visual Studio 2010 Tools for Office Runtime (x86 and x64) 설치 시 오류
10999정성태7/16/201624927오류 유형: 341. .NET Framework 4.5.2가 설치 안 되는 경우
10998정성태7/16/201624450.NET Framework: 598. C# - Excel 시트에 윈도우 폼 기능을 추가하는 방법 [1]파일 다운로드1
10997정성태7/16/201625812오류 유형: 340. HTTP Error 500.23 - Internal Server Error파일 다운로드1
10996정성태7/14/201630380Windows: 118. 유선 접속 상태에서 재부팅하면 무선 연결이 자동 연결 안되는 문제 [4]파일 다운로드1
10995정성태6/27/201623724VS.NET IDE: 109. Visual Studio 유료 버전 사용자의 주기적인 온라인 인증을 없애는 방법
10994정성태6/23/201622461개발 환경 구성: 285. 알고스팟(https://algospot.com)을 위한 Visual C++ 답안 작성 요령파일 다운로드1
10993정성태6/23/201624015.NET Framework: 597. 닷넷 메타데이터에 struct/class(값/참조 형식)의 구분이 있을까요?
10992정성태6/13/201620608오류 유형: 339. vbs 스크립트 실행 시 항상 실행 여부를 묻는 질문 창이 뜬다면?
10991정성태6/13/201626819오류 유형: 338. octave-gui 실행 시 "octave-gui.exe has stopped working" 오류
... 106  107  108  109  110  111  112  113  114  115  116  117  118  119  [120]  ...