Microsoft MVP성태의 닷넷 이야기
VC++: 31. 비스타에서 VS.NET 2005로 COM 프로젝트 빌드시 오류 [링크 복사], [링크+제목 복사],
조회: 24737
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

비스타에서 Visual C++ 8.0/9.0으로 COM 개체 관련 모듈을 개발하면 UAC로 인해, 컴파일 마지막 즈음에 다음과 같은 에러가 보고됩니다.

------ Build started: Project: TestCom, Configuration: Debug Win32 ------
Compiling...
SimpleCom.cpp
Linking...
Embedding manifest...
Registering output...
Project : error PRJ0050: Failed to register output. 
  Please try to register the component from a command prompt with elevated permissions.
Build log was saved at "file://c:\temp\vcpp\Debug\BuildLog.htm"
TestCom - 1 error(s), 0 warning(s)
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========

위의 영문과는 달리, 예전에 만들어 놓은 COM 프로젝트인 경우에는 다음과 같이 별로 친절하지 않은 에러가 보고되기도 합니다.

------ Build started: Project: TestCom, Configuration: Debug Win32 ------
;
Generating code
Finished generating code
Embedding manifest...
Generating XML documentation...
등록하고 있습니다.
Project : error PRJ0019: A tool returned an error code from "등록하고 있습니다."
Build log was saved at 
"file://c:\viewer\BuildLog.htm"
DxDocsViewer - 1 error(s), 0 warning(s)
========== Build: 0 succeeded, 1 failed, 5 up-to-date, 0 skipped ==========

어쨌든, 문제는 "오류"가 난다는 것인데요. 왜냐하면, medium 권한에서는 "HKLM"에 "쓰기" 작업이 금지되어 있기 때문입니다. 그럼, 이 문제를 어떻게 해결할 수 있을까요? 이에 대해서는 다음의 토픽에서 ^^; 지극히 간단한 답변을 내려주고 있습니다. (제 딴에는 혹시나 자동화 될 수 있는 수단이 VS.NET 2005 SP1에서 나왔을지도 모른다고 생각하고 찾아본 것이었습니다.)

UAC, Windows Vista & VS 2005
; https://devblogs.microsoft.com/cppblog/uac-windows-vista-vs-2005/

위의 토픽에서는 다음과 같은 3가지 방법을 제시하고 있습니다.

1. manifest 파일을 이용한 reg-free COM 개체로 변환.(링크) XP, 2003, Vista에서만 동작된다는 제한만 허용할 수 있다면 아예 개발 자체를 이렇게 가는 것이 좋겠습니다. 하지만, 다른 응용 프로그램의 플러그인으로 개발되는 경우라면 사용될 수 없을 것입니다.

2. 빌드 옵션에서 자동 등록 옵션을 빼고, 수작업으로 등록. 나쁘진 않은 방법입니다. 왜냐하면 COM 개체는 CLSID, PROGID, TypeLib 정도가 한번 등록되면 개발시에는 거의 바뀔 일이 없기 때문입니다. 물론, add-in을 만드는 과정 중간에 레지스트리 변경이 요구되는 단계에서는 수작업 등록을 다시 해줘야 합니다. (물론, batch 파일을 한번 만들어 두면 될 문제입니다.)

다음은 빌드 옵션을 조정하는 화면입니다. (자동 등록을 하지 않습니다.)

ide_vcpp_reg_error_1.png

3. VS.NET IDE를 아예 "관리 권한"으로 승격시켜서 빌드. 2번과 비슷한 경우라고 봐도 될 것입니다. 레지스트리 변경이 있을 때 마다 새롭게 IDE를 high 권한으로 띄우고 컴파일 해주면 되니까요.





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

[연관 글]






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

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

비밀번호

댓글 작성자
 



2007-02-01 09시45분
[WaterStone] 저는 주로 2번을 사용한답니다.
VS 2005의 external tools 에 customRunAs + regsvr32를 아예 등록해 놓고 툴바에 빼놓았죠.
customRunAs는 닷넷으로 runas를 구현한 것이고(암호 입력이 필요 없도록)...

그리고 등록이 필요한 경우에만 지긋이 툴바 버튼을 누른다는...
[guest]
2007-02-01 09시51분
말씀하신 방법이 가장 편리하겠는데요. ^^
kevin25

... 106  107  108  109  110  111  [112]  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11124정성태1/4/201727790개발 환경 구성: 309. 3년짜리 유효 기간을 제공하는 StartSSL [2]
11123정성태1/3/201723306.NET Framework: 629. .NET Core의 dotnet.exe CLI 명령어 확장 방법 [1]
11122정성태1/3/201722776.NET Framework: 628. TransactionScope에 사용자 정의 트랜잭션을 참여시키는 방법 [2]파일 다운로드1
11121정성태1/1/201720662개발 환경 구성: 308. "ASP.NET Core Web Application (.NET Core)"와 "ASP.NET Core Web Application (.NET Framework)" 차이점
11120정성태12/25/201626508개발 환경 구성: 307. ASP.NET Core Web Application을 IIS에서 호스팅하는 방법
11119정성태12/23/201649164개발 환경 구성: 306. Visual Studio Code에서 Python 개발 환경 구성 [2]
11118정성태12/22/201635940오류 유형: 374. Python 64비트 설치 시 0x80070659 오류 발생 [3]
11117정성태12/21/201622236웹: 35. nopCommerce 예제 사이트 구성 방법
11116정성태12/21/201624174디버깅 기술: 84. NopCommerce의 Autofac 부하(CPU, Memory) [2]
11115정성태12/21/201627160Windows: 133. 윈도우 서버 2016에서 플래시가 동작하지 않는 경우 [2]
11114정성태12/19/201637161Windows: 132. 역슬래시(backslash) 문자가 왜 통화 표기 문자(한글인 경우 "\")로 보일까요? [2]
11113정성태12/6/201621080오류 유형: 373. ICOMAdminCatalog::GetCollection에서 CO_E_ISOLEVELMISMATCH(0x8004E02F) 오류 발생파일 다운로드1
11112정성태11/23/201626273오류 유형: 372. MySQL 서비스가 올라오지 않는 경우 - Error 1067
11111정성태11/23/201634749.NET Framework: 627. C++로 만든 DLL을 C#에서 사용하기 [2]
11110정성태11/17/201621416.NET Framework: 626. Commit 메모리가 낮은 상황에서도 메모리 부족(Out-of-memory) 예외 발생 [2]
11109정성태11/17/201621369.NET Framework: 625. ASP.NET에서 System.Web.HttpApplication 인스턴스는 다중으로 생성됩니다.
11108정성태11/13/201621216.NET Framework: 624. WPF - Line 요소를 Canvas에 위치시켰을 때 흐림(blur) 현상파일 다운로드1
11107정성태11/9/201625110오류 유형: 371. Post cache substitution is not compatible with modules in the IIS integrated pipeline that modify the response buffers.파일 다운로드1
11106정성태11/8/201625276.NET Framework: 623. C# - PeerFinder를 이용한 Wi-Fi Direct 데이터 통신 예제 [2]파일 다운로드1
11105정성태11/8/201619656.NET Framework: 622. PeerFinder Wi-Fi Direct 통신 시 Read/Write/Dispose 문제
11104정성태11/8/201619128개발 환경 구성: 305. PeerFinder로 Wi-Fi Direct 연결 시 방화벽 문제
11103정성태11/8/201619098오류 유형: 370. PeerFinder.ConnectAsync의 결과 값인 Task.Result를 호출할 때 System.AggregateException 예외 발생
11102정성태11/8/201619152오류 유형: 369. PeerFinder.FindAllPeersAsync 호출 시 System.UnauthorizedAccessException 예외 발생
11101정성태11/8/201621978.NET Framework: 621. 닷넷 프로파일러의 오류 코드 - 0x80131363
11100정성태11/7/201628729개발 환경 구성: 304. Wi-Fi Direct 지원 여부 확인 방법 [1]
11099정성태11/7/201630693.NET Framework: 620. C#에서 C/C++ 함수로 콜백 함수를 전달하는 예제 코드파일 다운로드1
... 106  107  108  109  110  111  [112]  113  114  115  116  117  118  119  120  ...