Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 3개 있습니다.)
(시리즈 글이 4개 있습니다.)
닷넷: 2170. .NET Core/5+ 기반의 COM Server를 tlb 파일을 생성하는 방법(tlbexp)
; https://www.sysnet.pe.kr/2/0/13458

닷넷: 2171. .NET Core 3/5+ 기반의 COM Server를 기존의 regasm처럼 등록하는 방법
; https://www.sysnet.pe.kr/2/0/13459

닷넷: 2172. .NET 6+ 기반의 COM Server 내에 Type Library를 내장하는 방법
; https://www.sysnet.pe.kr/2/0/13460

닷넷: 2173. .NET Core 3/5+ 기반의 COM Server를 registry 등록 없이 사용하는 방법
; https://www.sysnet.pe.kr/2/0/13461




.NET Core 3/5+ 기반의 COM Server를 registry 등록 없이 사용하는 방법

.NET Core/5+에서 COM DLL을 만들 때 바뀐 것이 한두 개가 아니군요. ^^

.NET Core/5+ 기반의 COM Server를 tlb 파일을 생성하는 방법(tlbexp)
; https://www.sysnet.pe.kr/2/0/13458

.NET Core 3/5+ 기반의 COM Server를 기존의 regasm처럼 등록하는 방법
; https://www.sysnet.pe.kr/2/0/13459

.NET 6+ 기반의 COM Server 내에 Type Library를 내장하는 방법
; https://www.sysnet.pe.kr/2/0/13460

뿐만 아니라 tlbexp, regasm과 함께 reg-free COM 개체로 사용하는 방법도 편리하게 바뀌었습니다. 예전에는,

Registry 등록 과정 없이 COM 개체 사용 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/1167

사용자가 직접 manifest 파일 내용을 기술해야만 했는데, 이제는 .NET Core 3부터 msbuild 옵션으로,

<Project Sdk="Microsoft.NET.Sdk">
    <PropertyGroup>
        <!-- ...[생략]... -->
        <EnableRegFreeCom>true</EnableRegFreeCom>
    </PropertyGroup>
    <!-- ...[생략]... -->
</Project>

자동 생성해 줍니다. 위와 같이 EnableRegFreeCom 옵션을 넣으면 빌드 시 추가로 "ClassLibrary1.X.manifest" 파일이 생성되는데요, 내용은 대략 다음과 같습니다.

<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<assembly manifestVersion="1.0" xmlns="urn:schemas-microsoft-com:asm.v1">
    <assemblyIdentity type="win32" name="ClassLibrary1.X" version="1.0.0.0" />
    <file name="ClassLibrary1.comhost.dll">
        <comClass clsid="{41AC8568-9230-4E63-B7C5-CAAD997EE207}" threadingModel="Both" progid="ClassLibrary1.MyNetCode" />
    </file>
</assembly>

이것을 EXE 프로젝트 측의 manifest 정보에 병합하면 되는데요, 방법은 예전에 설명한 적이 있습니다. ^^

Visual Studio - C/C++ 프로젝트에 application manifest 적용하는 방법
; https://www.sysnet.pe.kr/2/0/13304

따라서 C++ 프로젝트에 "add.manifest" 파일을 하나 추가한 다음, 기본적으로는 아래와 같은 내용만 포함하면 될 테지만,

<?xml version='1.0' encoding='UTF-8' standalone='yes'?>
<assembly xmlns='urn:schemas-microsoft-com:asm.v1' manifestVersion='1.0'>
  <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
    <security>
      <requestedPrivileges>
        <requestedExecutionLevel level='asInvoker' uiAccess='false' />
      </requestedPrivileges>
    </security>
  </trustInfo>
</assembly>

C# 프로젝트의 결과물로 생성된 "ClassLibrary1.X.manifest" 파일의 내용을 필요한 부분만 복사해 주면,

<?xml version='1.0' encoding='UTF-8' standalone='yes'?>
<assembly xmlns='urn:schemas-microsoft-com:asm.v1' manifestVersion='1.0'>
  <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
    <security>
      <requestedPrivileges>
        <requestedExecutionLevel level='asInvoker' uiAccess='false' />
      </requestedPrivileges>
    </security>
  </trustInfo>

    <file name="ClassLibrary1.comhost.dll">
        <comClass clsid="{41AC8568-9230-4E63-B7C5-CAAD997EE207}" threadingModel="Both" progid="ClassLibrary1.MyNetCode" />
    </file>
</assembly>

끝입니다. 이제 C# COM 서버를 사용하는 C/C++ COM 클라이언트 응용 프로그램을 실행하기만 하면 (아무런 등록 작업 없이도) 정상적으로 코드가 동작합니다.




덕분에 개인적으로 만들어 두었던 COMRegFreeManifest 도구가,

Reg-free COM 개체 사용을 위한 manifest 파일 생성 도구 - COMRegFreeManifest
; https://www.sysnet.pe.kr/2/0/12160

C#으로 만든 COM 개체에 대해서는 필요 없게 되었습니다. ^^

첨부 파일은 이 글의 예제 코드를 반영했는데요, 다운로드 후 빌드를 (tlb 처리로 인해) 2번 한 후 ConsoleApplication1 프로젝트를 바로 실행하면 C# COM DLL 서버가 구동되는 것을 확인할 수 있습니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/2/2024]

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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  [186]  187  188  189  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
420정성태12/27/200627680Windows: 10. Internet Explorer 7.0 호환성 백서 (Word 문서, 1.92MB) [7]파일 다운로드1
419정성태12/25/200629710Windows: 9. VS.NET 2005 원격 디버깅 구성
418정성태12/25/200637824웹: 5. IIS 7에서 클라이언트 측 인증서 사용 시 주의점 [2]
417정성태12/24/200630018Windows: 8. VS.NET 2005에서의 웹 애플리케이션 디버깅 설정
416정성태1/31/200730289오류 유형: 23. MSI 설치 시 로그 파일 생성하는 레지스트리 설정 [3]
415정성태12/31/200634187개발 환경 구성: 20. 인증서 오류 체크 목록
413정성태12/20/200630625VC++: 26. volatile 키워드 [1]파일 다운로드1
412정성태12/17/200634748오류 유형: 22. VS.NET 2005 SP1 설치 도중 오류 [9]
411정성태12/16/200623820오류 유형: 21. TFS SP1 설치 관련 오류 (2) - KB919156 패치 이후 TFS 접근 문제
410정성태12/16/200624838오류 유형: 20. TFS SP1 설치 관련 오류 (1) - KB919156 패치
408정성태12/10/200627204Windows: 7. USB 드라이브 내용 암호화
407정성태12/10/200624175오류 유형: 19. Vista 에서의 VS.NET 2005 로 개발한 어셈블리에 대한 서명 확인 오류
406정성태12/10/200629440Windows: 6. IE 7 검색 공급자 - 영한 사전
403정성태12/6/200636551Windows: 5. Vista 와 웹 인증 등록 서비스의 문제 [5]
402정성태12/11/200627558Windows: 4. Vista 설치 후기 [1]
409정성태12/11/200631257    답변글 Windows: 4.1. Vista 설치 후기 - 두 번째 이야기 [3]
396정성태2/13/200734033오류 유형: 18. "Automatic Updates" 서비스 CPU 100% 점유 현상
393정성태11/8/200623806오류 유형: 17. Unable to start debugging - The binding handle is invalid.
371정성태10/23/200623164오류 유형: 16. STS Communication failed.
370정성태11/12/200626892.NET Framework: 75. Windows CardSpace 이야기 (이 글의 내용은 재작성되어질 예정입니다.)
375정성태10/25/200628596    답변글 .NET Framework: 75.1. 개인 발행 카드에 대한 Microsoft 예제 실습(이 글의 내용은 재작성되어질 예정입니다.)
376정성태10/27/200628475    답변글 .NET Framework: 75.2. "Windows CardSpace"와 "인증서 서비스"의 만남(이 글의 내용은 재작성되어질 예정입니다.)
377정성태10/26/200628212    답변글 .NET Framework: 75.3. Managed Card 발행에 대한 Microsoft 예제 실습 (1) - CardWriter (이 글의 내용은 재작성되어질 예정입니다.)
385정성태11/6/200630451    답변글 .NET Framework: 75.4. Managed Card 발행에 대한 Microsoft 예제 실습 (2) - STS 구현 (이 글의 내용은 재작성되어질 예정입니다.) [7]
387정성태11/2/200631652    답변글 .NET Framework: 75.5. Windows CardSpace와 SYSNET 사이트의 만남 (이 글의 내용은 재작성되어질 예정입니다.) [1]
397정성태11/11/200628978    답변글 .NET Framework: 75.6. CardWriter.csproj와 함께 알아보는 인증서 식별 방법(이 글의 내용은 재작성되어질 예정입니다.)
... 181  182  183  184  185  [186]  187  188  189  190  191  192  193  194  195  ...