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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
12545정성태3/2/202111456.NET Framework: 1026. 닷넷 5에 추가된 POH (Pinned Object Heap) [10]
12544정성태2/26/202111674.NET Framework: 1025. C# - Control의 Invalidate, Update, Refresh 차이점 [2]
12543정성태2/26/202110010VS.NET IDE: 158. C# - 디자인 타임(design-time)과 런타임(runtime)의 코드 실행 구분
12542정성태2/20/202112342개발 환경 구성: 544. github repo의 Release 활성화 및 Actions를 이용한 자동화 방법 [1]
12541정성태2/18/20219575개발 환경 구성: 543. 애저듣보잡 - Github Workflow/Actions 소개
12540정성태2/17/20219900.NET Framework: 1024. C# - Win32 API에 대한 P/Invoke를 대신하는 Microsoft.Windows.CsWin32 패키지
12539정성태2/16/20219807Windows: 189. WM_TIMER의 동작 방식 개요파일 다운로드1
12538정성태2/15/202110216.NET Framework: 1023. C# - GC 힙이 아닌 Native 힙에 인스턴스 생성 - 0SuperComicLib.LowLevel 라이브러리 소개 [2]
12537정성태2/11/202111269.NET Framework: 1022. UI 요소의 접근은 반드시 그 UI를 만든 스레드에서! - 두 번째 이야기 [2]
12536정성태2/9/202110217개발 환경 구성: 542. BDP(Bandwidth-delay product)와 TCP Receive Window
12535정성태2/9/20219371개발 환경 구성: 541. Wireshark로 확인하는 LSO(Large Send Offload), RSC(Receive Segment Coalescing) 옵션
12534정성태2/8/20219877개발 환경 구성: 540. Wireshark + C/C++로 확인하는 TCP 연결에서의 closesocket 동작 [1]파일 다운로드1
12533정성태2/8/20219591개발 환경 구성: 539. Wireshark + C/C++로 확인하는 TCP 연결에서의 shutdown 동작파일 다운로드1
12532정성태2/6/202110090개발 환경 구성: 538. Wireshark + C#으로 확인하는 ReceiveBufferSize(SO_RCVBUF), SendBufferSize(SO_SNDBUF) [3]
12531정성태2/5/20219080개발 환경 구성: 537. Wireshark + C#으로 확인하는 PSH flag와 Nagle 알고리듬파일 다운로드1
12530정성태2/4/202113296개발 환경 구성: 536. Wireshark + C#으로 확인하는 TCP 통신의 Receive Window
12529정성태2/4/202110307개발 환경 구성: 535. Wireshark + C#으로 확인하는 TCP 통신의 MIN RTO [1]
12528정성태2/1/20219719개발 환경 구성: 534. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 윈도우 환경
12527정성태2/1/20219896개발 환경 구성: 533. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 리눅스 환경파일 다운로드1
12526정성태2/1/20217724개발 환경 구성: 532. Azure Devops의 파이프라인 빌드 시 snk 파일 다루는 방법 - Secure file
12525정성태2/1/20217433개발 환경 구성: 531. Azure Devops - 파이프라인 실행 시 빌드 이벤트를 생략하는 방법
12524정성태1/31/20218574개발 환경 구성: 530. 기존 github 프로젝트를 Azure Devops의 빌드 Pipeline에 연결하는 방법 [1]
12523정성태1/31/20218635개발 환경 구성: 529. 기존 github 프로젝트를 Azure Devops의 Board에 연결하는 방법
12522정성태1/31/202110156개발 환경 구성: 528. 오라클 클라우드의 리눅스 VM - 9000 MTU Jumbo Frame 테스트
12521정성태1/31/202110099개발 환경 구성: 527. 이더넷(Ethernet) 환경의 TCP 통신에서 MSS(Maximum Segment Size) 확인 [1]
12520정성태1/30/20218642개발 환경 구성: 526. 오라클 클라우드의 VM에 ping ICMP 여는 방법
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...