문제

내 질문은 정확히 동일하지 않습니다 이 하나 (이론적이지 않으며 메시지 루프가없는 기본 스레드 만 있습니다. 시작 및 Exitinstance는 적합한 통화가 없습니다).

메시지 루프가없는 콘솔 앱을 사용하고 있습니다. 이 앱은로드 리브러 기능으로 EXE를로드하여 내보내기 기능을 사용할 수 있도록합니다. 나쁜 소식 : exe의 dllmain 함수는 호출되지 않습니다 (그리고 def 파일을 사용하여 기호 테이블을 확인했습니다. dllmain은 올바르게 나타납니다). 의사가 말합니다 로드 된 모듈이 DLL (너무 나쁘다) 인 경우 호출됩니다.

loadlibrary (그리고 Freelibrary가 호출 될 때 다시) 될 때 EXE의 dllmain 함수를 실행할 수있는 조건 (존재하는 경우)은 무엇입니까?

친애하는

도움이 되었습니까?

해결책

가장 명백한 조건은 LoadLibrary ()를 호출하는 프로세스가 명시 적으로 getProcadDress ( "dllmain")를 가져 와서 호출한다는 것입니다.

다른 팁

조건은 다음과 같습니다.

1)로드 된 이진을 DLL로 컴파일 하였다 (GCC/LD를 사용할 때는 사용을 의미합니다. --shared 옵션; 사용하는 경우 --shared, 결과 파일은 DLL이며 실행되지 않습니다. 아래 참조)

2) IMAGE_FILE_DLL 이진 파일의 PE 파일 헤더에로드됩니다. 설정된 경우 파일은 DLL이고 Windows Linker는 호출합니다. DllMain() 이 파일을 프로그램에 링크 할 때 기능합니다 (링크 된 방법은 중요하지 않습니다. LoadLibrary() 런타임 또는 -llibraryname 컴파일 시간에). 이를 위해 파일도 만족해야합니다 (1). 그러나이 플래그를 사용하면 이진 파일을로드 할 수 없습니다. 만약에 IMAGE_FILE_DLL 설정되지 않았습니다. DllMain() 파일이 프로그램에로드되면 호출되지 않습니다.

DLL을 컴파일합니다 --shared 그런 다음 수동으로 제거합니다 IMAGE_FILE_DLL 헤더에서 (즉, Hex 편집기를 사용하여) 작동하지 않습니다. DllMain() 실행되고 fdwReason 정의되지 않은 번호가됩니다 (0x28ffd4 내 기계에서).

업데이트

Windows의 모든 DLL 및 EXE 파일은 PE 파일이며 차이점은 연결 방법 및 헤더에 설정되는 플래그가 설정됩니다. 그것이 내가 쓰는 이유입니다 file being loaded, 아니다 dll being loaded.

마지막 단락은 파일을 DLL으로 컴파일하는 시나리오를 설명한 다음 헤더를 엉망으로하여 EXE로 바꿉니다. 작동하지 않습니다.

이름 지정은 그것과 관련이 없습니다 (이름을 선택할 수 있으며 일부 이름을 선택할 수 있습니다. pexports+dlltool Tinkering .exe 파일 용 가져 오기 라이브러리를 만들어 다음과 같이 연결할 수 있습니다. -lexenamewithoutextension

명확히하기 위해 :

  • 없이 컴파일하면 --shared:
    • IMAGE_FILE_DLL 설정되지 않으면 실행할 수 있지만 연결하면 DLLMAIN ()이 호출되지 않습니다.
  • 당신이 그것을 컴파일하면 --shared:
    • IMAGE_FILE_DLL 그것에 설정되면 실행할 수 없지만 링크 할 때 dllmain ()이 호출됩니다.
  • 없이 컴파일하면 --shared, 다음을 켜십시오 IMAGE_FILE_DLL 수동으로 플래그 :
    • 더 이상 실행할 수 없으며 링크 할 때 dllmain ()이 호출되지 않습니다.
  • 당신이 그것을 컴파일하면 --shared, 다음을 끕니다 IMAGE_FILE_DLL 수동으로 플래그 :
    • 실행 가능하지만 dllmain ()은 main () 대신 실행되며 연결하면 dllmain ()이 호출되지 않습니다.

실제로 함수의 "dllmain"이라는 이름은 Windows에 의해 완전히 무시됩니다 (Windows NT 3.x의 이전 Windows API 문서가 명시 적으로 언급되었습니다).

dll이로드되면 함수 dllmain ()이 아니라 파일의 진입 점에있는 함수가 호출됩니다.

물론 링커는 dllmain () 이이 함수 인 방식으로 dll 파일을 만듭니다.

그러나 EXE 파일의 경우 입력 함수 (WinMain ()이라고 부름)이 진입 점에 있습니다.

따라서 EXE 파일을 DLL로로드 할 때 Windows 가이 기능을 호출 할 수 없다는 것이 명백합니다.

좋은 답변을 완료합니다 msalters:

그러므로로드 리브러 직후와 프리 브리 브리 직전에 dll_xxx_detach와 함께 dll_xxx_attach로 "가짜"dllmain을 호출하고 다른 통화를 수동으로 만듭니다.

또 다른 구현은 가짜 dllmain에서 EXE를 자동으로 콜백 할 수있는 인터페이스 DLL을 빌드하고로드하는 것입니다 (작동 할 수 있는지 모르겠습니다). 그러나 여러 경우에 가짜 dllmain을 수동으로 부르는 것보다 더 복잡 할 수 있습니다. (dllmain에서 loadlibrary 할 수 없습니다)

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top