Microsoft MVP성태의 닷넷 이야기
VC++: 31. 비스타에서 VS.NET 2005로 COM 프로젝트 빌드시 오류 [링크 복사], [링크+제목 복사],
조회: 24683
글쓴 사람
정성태 (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

... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...
NoWriterDateCnt.TitleFile(s)
12111정성태1/12/202020549디버깅 기술: 155. C# - KernelMemoryIO 드라이버를 이용해 실행 프로그램을 숨기는 방법(DKOM: Direct Kernel Object Modification) [16]파일 다운로드1
12110정성태1/11/202019873디버깅 기술: 154. Patch Guard로 인해 블루 스크린(BSOD)가 발생하는 사례 [5]파일 다운로드1
12109정성태1/10/202016595오류 유형: 588. Driver 프로젝트 빌드 오류 - Inf2Cat error -2: "Inf2Cat, signability test failed."
12108정성태1/10/202017428오류 유형: 587. Kernel Driver 시작 시 127(The specified procedure could not be found.) 오류 메시지 발생
12107정성태1/10/202018611.NET Framework: 877. C# - 프로세스의 모든 핸들을 열람 - 두 번째 이야기
12106정성태1/8/202019653VC++: 136. C++ - OSR Driver Loader와 같은 Legacy 커널 드라이버 설치 프로그램 제작 [1]
12105정성태1/8/202018142디버깅 기술: 153. C# - PEB를 조작해 로드된 DLL을 숨기는 방법
12104정성태1/7/202019358DDK: 9. 커널 메모리를 읽고 쓰는 NT Legacy driver와 C# 클라이언트 프로그램 [4]
12103정성태1/7/202022492DDK: 8. Visual Studio 2019 + WDK Legacy Driver 제작- Hello World 예제 [1]파일 다운로드2
12102정성태1/6/202018818디버깅 기술: 152. User 권한(Ring 3)의 프로그램에서 _ETHREAD 주소(및 커널 메모리를 읽을 수 있다면 _EPROCESS 주소) 구하는 방법
12101정성태1/5/202019086.NET Framework: 876. C# - PEB(Process Environment Block)를 통해 로드된 모듈 목록 열람
12100정성태1/3/202016559.NET Framework: 875. .NET 3.5 이하에서 IntPtr.Add 사용
12099정성태1/3/202019435디버깅 기술: 151. Windows 10 - Process Explorer로 확인한 Handle 정보를 windbg에서 조회 [1]
12098정성태1/2/202019181.NET Framework: 874. C# - 커널 구조체의 Offset 값을 하드 코딩하지 않고 사용하는 방법 [3]
12097정성태1/2/202017239디버깅 기술: 150. windbg - Wow64, x86, x64에서의 커널 구조체(예: TEB) 구조체 확인
12096정성태12/30/201919898디버깅 기술: 149. C# - DbgEng.dll을 이용한 간단한 디버거 제작 [1]
12095정성태12/27/201921617VC++: 135. C++ - string_view의 동작 방식
12094정성태12/26/201919352.NET Framework: 873. C# - 코드를 통해 PDB 심벌 파일 다운로드 방법
12093정성태12/26/201918928.NET Framework: 872. C# - 로딩된 Native DLL의 export 함수 목록 출력파일 다운로드1
12092정성태12/25/201917673디버깅 기술: 148. cdb.exe를 이용해 (ntdll.dll 등에 정의된) 커널 구조체 출력하는 방법
12091정성태12/25/201919982디버깅 기술: 147. pdb 파일을 다운로드하기 위한 symchk.exe 실행에 필요한 최소 파일 [1]
12090정성태12/24/201920094.NET Framework: 871. .NET AnyCPU로 빌드된 PE 헤더의 로딩 전/후 차이점 [1]파일 다운로드1
12089정성태12/23/201919050디버깅 기술: 146. gflags와 _CrtIsMemoryBlock을 이용한 Heap 메모리 손상 여부 체크
12088정성태12/23/201917990Linux: 28. Linux - 윈도우의 "Run as different user" 기능을 shell에서 실행하는 방법
12087정성태12/21/201918461디버깅 기술: 145. windbg/sos - Dictionary의 entries 배열 내용을 모두 덤프하는 방법 (do_hashtable.py) [1]
12086정성태12/20/201920991디버깅 기술: 144. windbg - Marshal.FreeHGlobal에서 발생한 덤프 분석 사례
... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...