Microsoft MVP성태의 닷넷 이야기
Debug : 19. IsDebuggerPresent API 이야기 [링크 복사], [링크+제목 복사],
조회: 14039
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 


IsDebuggerPresent


.NET 응용 프로그램이 점차로 늘어가는 요즘 시기에, IsDebuggerPresent를 이야기한다는 것이 ^^ 이상하군요.

Native 응용 프로그램에서 IsDebuggerPresent API를 사용하는 경우는 아마도 Debugger를 통한 로직 검사를 막기 위해서일 것입니다. 하지만, 이 API를 호출한다고 해서 100% 막을 수는 없습니다.

John Robbins가 그의 책 "Debugging Applications ..."에서 이에 대해 짚어 놨지요. 간단하게 IsDebuggerPresent 함수가 0을 반환하도록 역공학 작업을 하면 된다는... 내용.

다음의 토픽은, 어려운 역공학까지 갈 것도 없이 간단하게 WinDBG에서 IsDebuggerPresent를 무력화시키는 방법을 소개하고 있습니다.

[Windbg Script] Disabling IsDebuggerPresent() 
; https://learn.microsoft.com/en-us/archive/blogs/debuggingtoolbox/windbg-script-disabling-isdebuggerpresent

이 때문에, John Robbins는 다음과 같은 inline 어셈블리 코드를 사용할 것을 그의 책에서 제안하고 있습니다.

BOOL AntiHackIsDebuggerPresent()
{
  BOOL bRet = TRUE;
  
  __asm
  {
    MOV EAX, FS:[00000018H]
    MOV EAX, DWORD PTR [EAX+030H]
    MOVZX EAX, BYTE PTR [EAX+002H]
    MOV bRet, EAX
  }
  
  return bRet;
}

참고로, 위의 코드에서는 inline 어셈블리 코드를 사용하고 있는데, "x64" 환경에서는 inline 어셈블리 코드가 지원되지 않으므로, 별도의 ASM 파일을 만들어서 외부 어셈블러로 컴파일 한 다음 링크를 시켜야 합니다. 이를 위해 "MASM for x64"(실행 파일명 ml64.exe)가 필요하며 이는 VS.NET 2005/Orcas를 설치하면 다음의 폴더에 위치해 있습니다.

ml64.exe 실행 파일 위치

VS.NET 2005 - C:\Program Files (x86)\Microsoft Visual Studio 8\VC\bin\amd64 
Orcas - C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC\bin\amd64

관련해서는 다음의 도움말을 참조할 수 있습니다.

Microsoft Macro Assembler Reference  
MASM for x64 (ml64.exe)  
; https://learn.microsoft.com/en-us/cpp/assembler/masm/microsoft-macro-assembler-reference



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







[최초 등록일: ]
[최종 수정일: 12/3/2022]


비밀번호

댓글 작성자
 




... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
725정성태4/22/200711482개발 환경 구성: 94. App.config 의 설정 분리 방법
724정성태4/20/200710748.NET 3.5 : 13. Orcas 베타 1 용 LINQ 예제
723정성태4/19/200711040.NET 3.5 : 12. LINQ 를 이용한 3tier 구성예
722정성태4/19/200710866Vista : 43. 레지스트리와 파일의 트랜잭션 지원
721정성태4/18/200710259개발 환경 구성: 93. Fiddler 와 VSTS WebTest
719정성태4/16/200710744Vista : 42. 리스트 뷰 컨트롤에서 항목을 선택할 때 Beep 발생
718정성태4/13/20079724개발 환경 구성: 92. 하드웨어 가상화 지원과 Virtual PC/Server
717정성태4/13/20079234.NET : 56. ASP.NET 컴파일 문제 관련 패치 공개
716정성태4/12/200710368Debug : 15. sos 를 이용한 System.Net.HttpWebRequest 패킷 살펴보기
715정성태4/10/200710090VS.NET IDE : 28. C# - 기본 참조되는 using 목록 변경
714정성태4/7/20079887개발 환경 구성: 91. 코드 == 문서화 ?
713정성태4/6/20079741개발 환경 구성: 90. VPC 크기 줄이는 방법
712정성태4/6/200710199개발 환경 구성: 89. Enterprise Library 3.0 릴리스
720정성태4/17/20079599    답변글 89.1 Policy Injection Application Block
711정성태4/5/20079964TFS : 95. Pre-caching your TFS Proxy
710정성태4/5/20079774Debug : 14. MSI 설치시 오류 로그 관련 팁
709정성태4/5/200710072.NET 3.0 : 18. WCF 호스팅 환경 구성
708정성태4/4/20079446TFS : 94. Guidance Explorer 를 이용한 Team System 커스터마이징
707정성태4/1/200710422.NET 3.0 : 17. WCF 성능 비교 자료
706정성태3/31/200710825Debug : 13. WinDbg 스크립트 사용 예제 - 연결 개체 풀링 검사
705정성태3/30/20079764TFS : 93. TFS Client 측에서의 로그 추적
704정성태3/30/20079483Debug : 12. Smart Client Application의 Performance Issue파일 다운로드1
703정성태3/29/200710369Vista : 41. IE 7 에서 "소스 보기" 하는 경우 보안 경고창 뜨는 것에 대해서.
702정성태3/28/20079493TFS : 92. Team System + Guidance Explorer
701정성태3/27/20079449개발 환경 구성: 88. 서브 프로젝트로 나뉜 웹 애플리케이션 구축 가이드
700정성태3/27/20079564Visual C++ : 9. 실행시에 Manifest 파일 선택
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...