Microsoft MVP성태의 닷넷 이야기
오류 유형: 79. DLL 'xxxxx.dll'을(를) 로드할 수 없습니다. [링크 복사], [링크+제목 복사],
조회: 57386
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)

DLL 'xxxxx.dll'을(를) 로드할 수 없습니다.


오늘, SignKorea라는 업체의 DLL을 DllImport 특성을 이용해서 연결시켰습니다. 그런데, 제 컴퓨터에서는 이상 없이 실행되었는데 다른 컴퓨터에서는 다음과 같은 오류를 내뱉었습니다.

DLL 'SKCommVB.DLL'을(를) 로드할 수 없습니다. 지정된 모듈을 찾을 수 없습니다. (예외가 발생한 HRESULT: 0x8007007E)


디버그상에서의 상세 오류 로그도 별반 다르지 않습니다.

이 대화 상자 대신 JIT(Just-in-time) 디버깅을 호출하는
방법에 대한 자세한 내용은 이 메시지의 뒷부분을 참조하십시오.

************** 예외 텍스트 **************
System.DllNotFoundException: DLL 'SKCommVB.DLL'을(를) 로드할 수 없습니다.
지정된 모듈을 찾을 수 없습니다. (예외가 발생한 HRESULT: 0x8007007E)
   위치: CommVB_Test.ImportAPI.UnsetMatchedContext()
   위치: CommVB_Test.Form1.Form1_Load(Object sender, EventArgs e) 파일 E:\Work\C#_CommVB\CommVB_Test\Form1.cs:줄 20
   위치: System.Windows.Forms.Form.OnLoad(EventArgs e)
   위치: System.Windows.Forms.Form.OnCreateControl()
   위치: System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible)
   위치: System.Windows.Forms.Control.CreateControl()
   위치: System.Windows.Forms.Control.WmShowWindow(Message& m)
   위치: System.Windows.Forms.Control.WndProc(Message& m)
   위치: System.Windows.Forms.ScrollableControl.WndProc(Message& m)
   위치: System.Windows.Forms.ContainerControl.WndProc(Message& m)
   위치: System.Windows.Forms.Form.WmShowWindow(Message& m)
   위치: System.Windows.Forms.Form.WndProc(Message& m)
   위치: System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
   위치: System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
   위치: System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)

... [이하 생략] ...

어지간히도 헤매게 만들었습니다. 왜냐하면, 분명히 SKCommVB.DLL이 같은 디렉토리에 있다는 것이 확실한데 이와 같은 오류가 나니 그저 황당할 뿐이었는데요. 그러다가 혹시나 싶어서 depends.exe(Dependency Walker)를 이용해서 확인해 보았습니다. 아니나 다를까,,, 다음과 같이 누락된 DLL이 있었습니다.

[그림 1: SKCommVB.dll - 누락된 NSLDAP32V11.dll]
skcommvb_interop_not_found_1.png

"
Error: At least one required implicit or forwarded dependency was not found.
Warning: At least one delay-load dependency module was not found.
Warning: At least one module has an unresolved import due to a missing export function in a delay-load dependent module.
"



모래 시계 표시가 있는 IEShims.dll이야 동적 로드 대상이다 보니 DllImport 특성으로 로드하는 순간에는 상관이 없지만, NSLDAP32V11.dll은 정적 링크된 것이기 때문에 사정이 다르죠. 그 때문에 "Error: At least one required implicit or forwarded dependency was not found."라는 오류 메시지가 있는 것입니다.

원래 정상이라면 아래와 같이 나와야 합니다.

[그림 2: SKCommVB.dll - 정상적으로 로드]
skcommvb_interop_not_found_2.png

암튼,,, 이것을 통해서 배운 시행착오라면. "DllImport" 특성이 적용된 API 실행 시 "DLL 'xxxxx.dll'을(를) 로드할 수 없습니다."와 같은 오류가 발생한다면 그것의 참조 DLL도 함께 조사해야 한다는 것!!!

그나저나, SignKorea 측에서는 이를 모르고 있을까요? 새로 설치된 "Clean PC"에서는 "NSLDAP32V11.DLL"로 인한 문제가 발생할 텐데...



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/23/2021]

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

비밀번호

댓글 작성자
 



2014-11-10 06시42분
[YCPark] 좋은 정보 감사합니다 :D
덕분에 문제 해결하고 가네요
[guest]

... 91  92  93  94  95  96  97  98  99  [100]  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11467정성태3/19/201817453오류 유형: 455. Visual Studio Installer - 업데이트 실패
11466정성태3/18/201818051개발 환경 구성: 355. 한 대의 PC에서 2개 이상의 DirectX 게임을 실행하는 방법
11463정성태3/15/201820308.NET Framework: 733. 스레드 간의 read/write 시에도 lock이 필요 없는 경우파일 다운로드1
11462정성태3/14/201823913개발 환경 구성: 354. HTTPS 호출에 대한 TLS 설정 확인하는 방법 [1]
11461정성태3/13/201826292오류 유형: 454. 윈도우 업데이트 설치 오류 - 0x800705b4 [1]
11460정성태3/13/201818390디버깅 기술: 112. windbg - 닷넷 메모리 덤프에서 전역 객체의 내용을 조사하는 방법
11459정성태3/13/201819623오류 유형: 453. Debug Diagnostic Tool에서 mscordacwks.dll을 찾지 못하는 문제
11458정성태2/21/201820485오류 유형: 452. This share requires the obsolete SMB1 protocol, which is unsafe and could expose your system to attack. [1]
11457정성태2/17/201824651.NET Framework: 732. C# - Task.ContinueWith 설명 [1]파일 다운로드1
11456정성태2/17/201830755.NET Framework: 731. C# - await을 Task 타입이 아닌 사용자 정의 타입에 적용하는 방법 [7]파일 다운로드1
11455정성태2/17/201819964오류 유형: 451. ASP.NET Core - An error occurred during the compilation of a resource required to process this request.
11454정성태2/12/201828923기타: 71. 만료된 Office 제품 키를 변경하는 방법
11453정성태1/31/201820738오류 유형: 450. Azure Cloud Services(classic) 배포 시 "Certificate with thumbprint ... doesn't exist." 오류 발생
11452정성태1/31/201826118기타: 70. 재현 가능한 최소한의 예제 프로젝트란? [3]파일 다운로드1
11451정성태1/24/201819918디버깅 기술: 111. windbg - x86 메모리 덤프 분석 시 닷넷 메서드의 호출 인자 값 확인
11450정성태1/24/201836181Windows: 146. PowerShell로 원격 프로세스(EXE, BAT) 실행하는 방법 [1]
11449정성태1/23/201822862오류 유형: 449. 단위 테스트 - Could not load file or assembly 'Microsoft.VisualStudio.QualityTools.VideoRecorderEngine' or one of its dependencies. [1]
11448정성태1/20/201820955오류 유형: 448. Fakes를 포함한 단위 테스트 프로젝트를 빌드 시 CS0619 관련 오류 발생
11447정성태1/20/201822217.NET Framework: 730. dotnet user-secrets 명령어 [2]파일 다운로드1
11446정성태1/20/201822533.NET Framework: 729. windbg로 살펴보는 GC heap의 Segment 구조 [2]파일 다운로드1
11445정성태1/20/201820827.NET Framework: 728. windbg - 눈으로 확인하는 Workstation GC / Server GC
11444정성태1/19/201820379VS.NET IDE: 125. Visual Studio에서 Selenium WebDriver를 이용한 웹 브라우저 단위 테스트 구성파일 다운로드1
11443정성태1/18/201821821VC++: 124. libuv 모듈 살펴 보기
11442정성태1/18/201818856개발 환경 구성: 353. ASP.NET Core 프로젝트의 "Enable unmanaged code debugging" 옵션 켜는 방법
11441정성태1/18/201817300오류 유형: 447. ASP.NET Core 배포 오류 - Ensure that restore has run and that you have included '...' in the TargetFrameworks for your project.
11440정성태1/17/201820609.NET Framework: 727. ASP.NET의 HttpContext.Current 구현에 대응하는 ASP.NET Core의 IHttpContextAccessor/HttpContextAccessor 사용법파일 다운로드1
... 91  92  93  94  95  96  97  98  99  [100]  101  102  103  104  105  ...