Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)
(시리즈 글이 8개 있습니다.)
VC++: 29. 필수 무결성 제어를 조절하는 방법(1) - Manifest 파일 이용
; https://www.sysnet.pe.kr/2/0/445

VC++: 30. 필수 무결성 제어를 조절하는 방법(2) - 직접 코딩
; https://www.sysnet.pe.kr/2/0/446

VS.NET IDE: 43. .NET에서의 필수 무결성 제어 조절하는 방법 - Manifest 파일 이용
; https://www.sysnet.pe.kr/2/0/450

VS.NET IDE: 50. Orcas - UAC 설정 관련
; https://www.sysnet.pe.kr/2/0/507

개발 환경 구성: 320. Visual Basic .NET 프로젝트에서 내장 Manifest 자원을 EXE 파일로부터 제거하는 방법
; https://www.sysnet.pe.kr/2/0/11228

VS.NET IDE: 122. 비주얼 스튜디오에서 관리자 권한을 요구하는 C# 콘솔 프로그램 제작
; https://www.sysnet.pe.kr/2/0/11318

개발 환경 구성: 572. .NET에서의 신뢰도 등급 조정 - 외부 Manifest 파일을 두는 방법
; https://www.sysnet.pe.kr/2/0/12634

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





.NET에서의 필수 무결성 제어(신뢰도 등급) 조정 - Manifest 파일 이용


지난 토픽에서 이미 VC++ 개발자 입장에서 필수 무결성 제어(신뢰도 등급)을 조정하는 방법을 2가지 알아봤었습니다.

VC++: 필수 무결성 제어(신뢰도 등급)을 조절하는 방법(1) - Manifest 파일 이용 
; https://www.sysnet.pe.kr/2/0/445

VC++: 필수 무결성 제어(신뢰도 등급)을 조절하는 방법(2) - 직접 코딩 
; https://www.sysnet.pe.kr/2/0/446

그럼, ".NET"에서는 어떻게 다뤄질 수 있을까요? 우선, 필수 무결성 제어(신뢰도 등급)의 직접 코딩 방식은 아직 .NET 3.0에서 명시적으로 지원되지 않습니다. 향후의 .NET 3.5는 아직 개선중이라서 이에 대한 반영이 될지는 장담할 수 없지만, 현재 이용이 가능한 최선의 방법은 P/Invoke를 사용한 Win32 API의 호출 밖에는 없는 듯 보입니다.

반면에, "manifest"를 이용하는 방법은 VC++과 비슷한 수준에서 쉽게 구성할 수 있습니다. 일단, 이번 토픽에서는 .NET 코딩을 통한 필수 무결성 제어(신뢰도 등급) 향상은 생략하고, Manifest 파일을 통한 필수 무결성 제어(신뢰도 등급) 향상 방법에 대해서만 이야기를 해보겠습니다.




[Manifest 파일을 내장하는 방법]
1. VS.NET 2005에서 C# 콘솔 응용 프로그램 프로젝트를 생성합니다.

2. 다음과 같은 내용을 포함한 "UacManifest.RC" 파일을 생성합니다.(이름은 임의로 지어도 됩니다.)

#include <winuser.h>
#define IDR_MANIFEST 1 // 2 for a DLL

IDR_MANIFEST RT_MANIFEST MOVEABLE PURE
{
    "<assembly xmlns=""urn:schemas-microsoft-com:asm.v1"" manifestVersion=""1.0"">
       <asmv3:trustInfo xmlns:asmv3=""urn:schemas-microsoft-com:asm.v3"">
         <asmv3:security>
           <asmv3:requestedPrivileges>
             <asmv3:requestedExecutionLevel
               level=""requireAdministrator""
               uiAccess=""false"" />
           </asmv3:requestedPrivileges>
         </asmv3:security>
       </asmv3:trustInfo>
     </assembly>"
}

3. 위의 "UacManifest.RC" 파일을 "rc.exe" 리소스 컴파일러로 컴파일합니다. "rc.exe" 파일은 VS.NET 2005에서 VC++ 부분을 설치한 경우에 "C:\Program Files\Microsoft Visual Studio 8\VC\bin\rc.exe"로 존재하게 됩니다. 만약 VC++이 없는 상태라면, "Windows SDK"를 설치하시면 "C:\Program Files\Microsoft SDKs\Windows\v6.0\Bin\rc.exe"로 포함되어 있으니 그것을 사용하셔도 됩니다.

 C:>rc.exe UacManifest.RC

위와 같이 실행하게 되면 "uacmanifest.RES" 파일이 생성됩니다.

4. C# 프로젝트 속성창에서 3번 단계에서 생성된 "uacmanifest.RES" 파일을 다음과 같이 지정해 줍니다.

requestedExecutionLevel_manifest_1.png

5. 자, 완료되었습니다. ^^ 이제 빌드하고 실행시켜 보시면 해당 콘솔 응용 프로그램이 실행될 때마다 자동으로 "UAC 확인창"이 뜨는 것을 볼 수 있습니다.




[Manifest 내용을 외부 파일로 두는 방법]
위에서 살펴본 방식은 Manifest 파일을 내장하는 방법을 설명한 것입니다. VC++에서도 설명했듯이 manifest 파일은 리소스로 포함하는 방식과 외부 파일로 빼는 방식이 있는데, .NET 역시 manifest 파일을 외부로 빼는 방식이 가능합니다. 단지 VC++에서와 다른 점이 있다면, .NET 응용 프로그램의 경우에는 그냥 아무런 프로젝트 설정을 하지 않고도 exe 파일명에 ".manifest" 확장자만 붙인 별도의 파일을 두는 식으로 간단하게 해결된다는 점입니다.

하지만, 그와 같이 manifest 파일을 직접 수작업으로 관리해주는 것은 아무래도 ^^ 좀 원시적으로 보이죠. 기왕이면 프로젝트 속성창 단계에서 그와 같은 관리를 해주면 좋을 텐데, (Orcas에서는 바뀔지 모르지만) 직접적으로 Manifest 파일만을 위한 옵션은 제공되지 않고 "ClickOnce"를 위한 설정에 얹어서 가는 방법만이 제공되고 있습니다. 어쨌든, 그 방식이 나름대로는 편하니 마저 알아보도록 하겠습니다.

1. VS.NET 2005에서 C# 콘솔 응용 프로그램 프로젝트를 생성합니다.

2. 아래에서 보는 것처럼, 프로젝트 속성창의 "Security" 설정에서 "Enable ClickOnce Security Settings"를 선택해 둡니다.

net_manifest_settings_1.png

3. 위와 같이 선택해 두면, 프로젝트에 2가지 변화가 나타납니다. 첫번째는 "Properties" 폴더에 "Build Action"이 "BaseApplicationManifest" 값으로 설정된 "app.manifest" 항목이 생성되는 것을 확인할 수 있습니다.

net_manifest_settings_2.png

두번째는, csproj 프로젝트 파일을 직접 열어봐야만 확인이 가능한데, 아래에서 보는 것처럼 GenerateManifests 옵션값이 true로 설정된다는 점입니다.

<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
  <PropertyGroup>
    <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
    ;
    ;
    <GenerateManifests>true</GenerateManifests>
  </PropertyGroup>

이로 인해, app.config을 다루던 식과 비슷하게, 해당 프로젝트가 빌드되면 대상 폴더에 "app.manifest" 파일이 "ConsoleApplication1.exe.manifest" 파일로 이름이 바뀌어 생성되는 것을 확인할 수 있습니다.

4. UAC 확인창을 띄우기 위해서, "app.manifest" 파일을 열어서 다음과 같이 편집을 합니다.

<?xml version="1.0" encoding="utf-8"?>
<asmv1:assembly manifestVersion="1.0" xmlns="urn:schemas-microsoft-com:asm.v1" xmlns:asmv1="urn:schemas-microsoft-com:asm.v1" xmlns:asmv2="urn:schemas-microsoft-com:asm.v2" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
    <security>
      <applicationRequestMinimum>
        <defaultAssemblyRequest permissionSetReference="Custom" />
        <PermissionSet class="System.Security.PermissionSet" version="1" Unrestricted="true" ID="Custom" SameSite="site" />
      </applicationRequestMinimum>
      <requestedPrivileges> 
          <requestedExecutionLevel level="requireAdministrator" uiAccess="false" />
      </requestedPrivileges>
    </security>
  </trustInfo>
</asmv1:assembly>

5. 자, 이제 모든 준비는 끝났습니다. 빌드하고 나서 "ConsoleApplication1.exe" 파일을 실행시키면 정상적으로 UAC 확인창이 뜨는 것을 확인할 수 있습니다.



첨부된 압축 파일은 여기서 설명된 예제 프로젝트를 포함하고 있습니다.

MyApp.zip: 내장 Manifest 파일 예제
ConsoleApplication1.zip: 외부 Manifest 파일 예제


[내용 추가: 2007-01-30]
예전에 COM 개체 등록을 대신하는 manifest에 대한 토픽을 쓴 적이 있었네요.
그냥 실습만 해보고 기록은 하지 않았다고 생각했었는데... ^^; 다음의 토픽을 참고하십시오.
Registry 등록 없이 COM 개체 사용 
; https://www.sysnet.pe.kr/2/1/262

Escape DLL Hell - Simplify App Deployment with ClickOnce and Registration-Free COM 
; https://learn.microsoft.com/en-us/archive/msdn-magazine/2005/april/simplify-app-deployment-with-clickonce-and-registration-free-com



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/9/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)
13607정성태4/25/2024198닷넷: 2248.C# - 인터페이스 타입의 다중 포인터를 인자로 갖는 C/C++ 함수 연동
13606정성태4/24/2024217닷넷: 2247. C# - tensorflow 연동 (MNIST 예제)파일 다운로드1
13605정성태4/23/2024457닷넷: 2246. C# - Python.NET을 이용한 파이썬 소스코드 연동파일 다운로드1
13604정성태4/22/2024508오류 유형: 901. Visual Studio - Unable to set the next statement. Set next statement cannot be used in '[Exception]' call stack frames.
13603정성태4/21/2024735닷넷: 2245. C# - IronPython을 이용한 파이썬 소스코드 연동파일 다운로드1
13602정성태4/20/2024811닷넷: 2244. C# - PCM 오디오 데이터를 연속(Streaming) 재생 (Windows Multimedia)파일 다운로드1
13601정성태4/19/2024859닷넷: 2243. C# - PCM 사운드 재생(NAudio)파일 다운로드1
13600정성태4/18/2024899닷넷: 2242. C# - 관리 스레드와 비관리 스레드
13599정성태4/17/2024875닷넷: 2241. C# - WAV 파일의 PCM 사운드 재생(Windows Multimedia)파일 다운로드1
13598정성태4/16/2024901닷넷: 2240. C# - WAV 파일 포맷 + LIST 헤더파일 다운로드2
13597정성태4/15/2024883닷넷: 2239. C# - WAV 파일의 PCM 데이터 생성 및 출력파일 다운로드1
13596정성태4/14/20241076닷넷: 2238. C# - WAV 기본 파일 포맷파일 다운로드1
13595정성태4/13/20241054닷넷: 2237. C# - Audio 장치 열기 (Windows Multimedia, NAudio)파일 다운로드1
13594정성태4/12/20241069닷넷: 2236. C# - Audio 장치 열람 (Windows Multimedia, NAudio)파일 다운로드1
13593정성태4/8/20241087닷넷: 2235. MSBuild - AccelerateBuildsInVisualStudio 옵션
13592정성태4/2/20241225C/C++: 165. CLion으로 만든 Rust Win32 DLL을 C#과 연동
13591정성태4/2/20241200닷넷: 2234. C# - WPF 응용 프로그램에 Blazor App 통합파일 다운로드1
13590정성태3/31/20241079Linux: 70. Python - uwsgi 응용 프로그램이 k8s 환경에서 OOM 발생하는 문제
13589정성태3/29/20241158닷넷: 2233. C# - 프로세스 CPU 사용량을 나타내는 성능 카운터와 Win32 API파일 다운로드1
13588정성태3/28/20241272닷넷: 2232. C# - Unity + 닷넷 App(WinForms/WPF) 간의 Named Pipe 통신 [2]파일 다운로드1
13587정성태3/27/20241172오류 유형: 900. Windows Update 오류 - 8024402C, 80070643
13586정성태3/27/20241340Windows: 263. Windows - 복구 파티션(Recovery Partition) 용량을 늘리는 방법
13585정성태3/26/20241145Windows: 262. PerformanceCounter의 InstanceName에 pid를 추가한 "Process V2"
13584정성태3/26/20241273개발 환경 구성: 708. Unity3D - C# Windows Forms / WPF Application에 통합하는 방법파일 다운로드1
13583정성태3/25/20241489Windows: 261. CPU Utilization이 100% 넘는 경우를 성능 카운터로 확인하는 방법
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...