Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 4개 있습니다.)
(시리즈 글이 5개 있습니다.)
.NET Framework: 318. gacutil.exe로 어셈블리 등록 시 시스템 변경 사항
; https://www.sysnet.pe.kr/2/0/1285

.NET Framework: 319. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (1) - .NET 2.0 + x86/x64/AnyCPU
; https://www.sysnet.pe.kr/2/0/1286

.NET Framework: 320. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (2) - .NET 4.0 + .NET 2.0
; https://www.sysnet.pe.kr/2/0/1287

.NET Framework: 321. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (3) - Type Library
; https://www.sysnet.pe.kr/2/0/1288

.NET Framework: 322. regsvcs.exe로 어셈블리 등록 시 시스템 변경 사항
; https://www.sysnet.pe.kr/2/0/1289




regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (3) - Type Library

지난번 글에 이어서,

regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (2) - .NET 4.0 + .NET 2.0
; https://www.sysnet.pe.kr/2/0/1287

예제를 다양화하기 위해 그 당시 테스트 환경을 다음과 같이 3개의 프로젝트로 분리했습니다.

regasm_tlb_1.png

ComBaseClass는 IAdminCode.cs 인터페이스를 보관해서, ConsoleApplication1 프로젝트와 ClassLibraryAsAdmin 프로젝트의 직접적인 참조관계를 끊어버렸습니다. 이렇게 예제를 바꾸면 관리해야 할 DLL이 한 개 더 늘어나므로 약간 귀찮은 면은 있습니다.

어쨌든, 여기까지 적용된 시스템 변경 사항은 다음과 같습니다.

=== ClassLibraryAsAdmin의 CLSID/ProgId ===
ClassLibraryAsAdmin.AdminCode
CLSID\{41AC8568-9230-4E63-B7C5-CAAD997EE207}
Wow6432Node\ClassLibraryAsAdmin.AdminCode
Wow6432Node\CLSID\{41AC8568-9230-4E63-B7C5-CAAD997EE207}

=== GAC에 등록된 2개의 DLL 파일 ===
c:\windows\assembly\GAC_MSIL\ComBaseClass\1.0.0.0__c91e971f6240da9f\ComBaseClass.dll
c:\windows\assembly\GAC_MSIL\ClassLibraryAsAdmin\1.0.0.0__465ff3ec4fc809d7\ClassLibraryAsAdmin.dll

나아가서, regasm.exe에서 /tlb 옵션을 주어 등록을 하면 어떻게 될까요?

%windir%\Microsoft.NET\Framework\v2.0.50727\regasm.exe ComBaseClass.dll /tlb
%windir%\Microsoft.NET\Framework\v2.0.50727\regasm.exe ClassLibraryAsAdmin.dll /tlb

그러면, 제법 많은 변화가 발생합니다. 우선, 인터페이스가 레지스트리에 등록되고,

=== ComBaseClass.dll에 정의된 인터페이스 ===
Interface\{23172F2F-A3D3-4180-97AE-7805F74A5A46}
Wow6432Node\Interface\{23172F2F-A3D3-4180-97AE-7805F74A5A46}

=== ClassLibraryAsAdmin.dll에 정의된 인터페이스 ===
Interface\{D7CE4B41-D2A5-3CCD-BF38-5B8197825E09}
Wow6432Node\Interface\{D7CE4B41-D2A5-3CCD-BF38-5B8197825E09}

이어서 해당 인터페이스에 정의된 레지스트리를 가보면 다음과 같이 TypeLib가 연결된 것을 볼 수 있습니다.

regasm_tlb_2.png

그리고, 각각의 타입라이브러리를 찾아가보면,

HKEY_CLASSES_ROOT\TypeLib\{728F14FE-B021-43EF-8AAC-D37A4AF5ED6A}
HKEY_CLASSES_ROOT\Wow6432Node\TypeLib\{728F14FE-B021-43EF-8AAC-D37A4AF5ED6A}

다음과 같이 regasm.exe /tlb 옵션으로 해당 폴더에 생성된 TLB 파일을 가리키는 것을 확인할 수 있습니다.

regasm_tlb_3.png

마지막으로 Type Library까지 등록된 경우 시스템에 가해지는 변경 사항은 다음과 같습니다.

=== ClassLibraryAsAdmin에 대한 ProgId/CLSID ===
ClassLibraryAsAdmin.AdminCode
CLSID\{41AC8568-9230-4E63-B7C5-CAAD997EE207}
Wow6432Node\ClassLibraryAsAdmin.AdminCode
Wow6432Node\CLSID\{41AC8568-9230-4E63-B7C5-CAAD997EE207}

=== ClassLibraryAsAdmin에 대한 TypeLibrary ===
TypeLib\{728F14FE-B021-43EF-8AAC-D37A4AF5ED6A}
Wow6432Node\TypeLib\{728F14FE-B021-43EF-8AAC-D37A4AF5ED6A}

=== ComBaseClass에 대한 TypeLibrary ===
TypeLib\{1CCE4407-4EA5-4A60-BAF8-809AB169CE4D}
Wow6432Node\TypeLib\{1CCE4407-4EA5-4A60-BAF8-809AB169CE4D}

=== ClassLibraryAsAdmin에 대한 Interface === 
Interface\{D7CE4B41-D2A5-3CCD-BF38-5B8197825E09}
Wow6432Node\Interface\{D7CE4B41-D2A5-3CCD-BF38-5B8197825E09}

=== ComBaseClass에 대한 Interface === 
Interface\{23172F2F-A3D3-4180-97AE-7805F74A5A46}
Wow6432Node\Interface\{23172F2F-A3D3-4180-97AE-7805F74A5A46}

파일은 TLB 파일까지 포함하게 되어 4개로 늘어납니다.

c:\windows\assembly\GAC_MSIL\ComBaseClass\1.0.0.0__c91e971f6240da9f\ComBaseClass.dll
c:\windows\assembly\GAC_MSIL\ClassLibraryAsAdmin\1.0.0.0__465ff3ec4fc809d7\ClassLibraryAsAdmin.dll

D:\temp\net20\AnyCPU\ClassLibraryAsAdmin.tlb
D:\temp\net20\AnyCPU\ComBaseClass.tlb

regasm.exe의 등록으로 인한 시스템 변경 사항은 여기까지가 끝입니다. ^^

* 첨부된 파일은 여기까지 실습을 해온 간단한 3개의 프로젝트를 포함합니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 11/30/2023]

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

비밀번호

댓글 작성자
 




1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13576정성태3/8/20241543닷넷: 2228. .NET Profiler - IMetaDataEmit2::DefineMethodSpec 사용법
13575정성태3/7/20241676닷넷: 2227. 최신 C# 문법을 .NET Framework 프로젝트에 쓸 수 있을까요?
13574정성태3/6/20241557닷넷: 2226. C# - "Docker Desktop for Windows" Container 환경에서의 IPv6 DualMode 소켓
13573정성태3/5/20241563닷넷: 2225. Windbg - dumasync로 분석하는 async/await 호출
13572정성태3/4/20241643닷넷: 2224. C# - WPF의 Dispatcher Queue로 알아보는 await 호출의 hang 현상파일 다운로드1
13571정성태3/1/20241621닷넷: 2223. C# - await 호출과 WPF의 Dispatcher Queue 동작 확인파일 다운로드1
13570정성태2/29/20241635닷넷: 2222. C# - WPF의 Dispatcher Queue 동작 확인파일 다운로드1
13569정성태2/28/20241545닷넷: 2221. C# - LoadContext, LoadFromContext 그리고 GAC파일 다운로드1
13568정성태2/27/20241606닷넷: 2220. C# - .NET Framework 프로세스의 LoaderOptimization 설정을 확인하는 방법파일 다운로드1
13567정성태2/27/20241618오류 유형: 898. .NET Framework 3.5 이하에서 mscoree.tlb 참조 시 System.BadImageFormatException파일 다운로드1
13566정성태2/27/20241631오류 유형: 897. Windows 7 SDK 설치 시 ".NET Development" 옵션이 비활성으로 선택이 안 되는 경우
13565정성태2/23/20241479닷넷: 2219. .NET CLR2 보안 모델에서의 개별 System.Security.Permissions 제어
13564정성태2/22/20241614Windows: 259. Hyper-V Generation 1 유형의 VM을 Generation 2 유형으로 바꾸는 방법
13563정성태2/21/20241646디버깅 기술: 196. windbg - async/await 비동기인 경우 메모리 덤프 분석의 어려움
13562정성태2/21/20241646오류 유형: 896. ASP.NET - .NET Framework 기본 예제에서 System.Web에 대한 System.IO.FileNotFoundException 예외 발생
13561정성태2/20/20241744닷넷: 2218. C# - (예를 들어, Socket) 비동기 I/O에 대한 await 호출 시 CancellationToken을 이용한 취소파일 다운로드1
13560정성태2/19/20241747디버깅 기술: 195. windbg 분석 사례 - Semaphore 잠금으로 인한 Hang 현상 (닷넷)
13559정성태2/19/20242625오류 유형: 895. ASP.NET - System.Security.SecurityException: 'Requested registry access is not allowed.'
13558정성태2/18/20241820닷넷: 2217. C# - 최댓값이 1인 SemaphoreSlim 보다 Mutex 또는 lock(obj)를 선택하는 것이 나은 이유
13557정성태2/18/20241620Windows: 258. Task Scheduler의 Author 속성 값을 변경하는 방법
13556정성태2/17/20241684Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/20241955닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/20241709VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20241736닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20241693닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/20242017닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...