Windows 7용 manifest 삽질기


많은 분들의 도움 덕분에 VCi 2.3에서 드래그앤 드롭이 정상동작 하지 않던 문제의 원인을 확인했다.
원인을 알고보니, 혹시나 걱정했던 문제[각주:1]가 아닌 manifest를 잘못 지정한 것이 원인이었다.

Windows XP 시절에 uxtheme를 적용하기 위해 사용되던 manifest는 이런 형태였다. (이하 manifest-1)

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1"
        manifestVersion="1.0">
<assemblyIdentity
    version="1.0.0.0"
    processorArchitecture="X86"
    name="Microsoft.Windows.YourApplication"
    type="win32"
/>
<description>YourApplication</description>
<dependency>
    <dependentAssembly>
        <assemblyIdentity
            type="win32"
            name="Microsoft.Windows.Common-Controls"
            version="6.0.0.0"
            processorArchitecture="X86"
            publicKeyToken="6595b64144ccf1df"
            language="*"
        />
    </dependentAssembly>
</dependency>
</assembly>

Vista/Win7 시절로 접어들면서 manifest를 통해 실행 권한을 부여하게 되었다.
아래와 같은 형태가 가장 기본적으로 적용되는 표준형 manifest이다. (이하 manifest-2)

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1"
        manifestVersion="1.0">
<assemblyIdentity
    version="1.0.0.0"
    processorArchitecture="X86"
    name="Microsoft.Windows.YourApplication"
    type="win32"
/>
<description>YourApplication</description>
<dependency>
    <dependentAssembly>
        <assemblyIdentity
            type="win32"
            name="Microsoft.Windows.Common-Controls"
            version="6.0.0.0"
            processorArchitecture="X86"
            publicKeyToken="6595b64144ccf1df"
            language="*"
        />
    </dependentAssembly>
</dependency>
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
<security>
<requestedPrivileges>
<requestedExecutionLevel level="asInvoker" />
</requestedPrivileges>
</security>
</trustInfo>
</assembly>

그런데, 어디선가 주워들은 것이, Privilege를 더 높이면 항상 관리자 모드로 실행된다는 얘기였다.
아니! 그렇다면 manifest를 잘 지정하면 Windows 7에서 안정성을 높일 수 있다는 얘기이지 않은가!
그래서 지정한 형태가 아래와 같은 형태이다. (manifest-3)

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1"
        manifestVersion="1.0">
<assemblyIdentity
    version="1.0.0.0"
    processorArchitecture="X86"
    name="Microsoft.Windows.YourApplication"
    type="win32"
/>
<description>YourApplication</description>
<dependency>
    <dependentAssembly>
        <assemblyIdentity
            type="win32"
            name="Microsoft.Windows.Common-Controls"
            version="6.0.0.0"
            processorArchitecture="X86"
            publicKeyToken="6595b64144ccf1df"
            language="*"
        />
    </dependentAssembly>
</dependency>
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
<security>
<requestedPrivileges>
<requestedExecutionLevel
level="requireAdministrator"
uiAccess="False"/>
</requestedPrivileges>
</security>
</trustInfo>
</assembly>

그리고, VCi 2.3manifest-3을 적용하여 많은 PC에서 잘 동작하는 것을 확인했다.
그런데, 여러가지로 확인해본 결과 manifest-3은 일부 Windows 7에서 정상동작하지 않는 문제가 있었다.

결국 manifest-2로 돌아갔고, 잘 동작한다는 것을 확인했다. 휴~

덧. 도움을 주신 모든 분들께 감사드립니다. 고맙습니다. 꾸벅.

  1. Visual C++ 6.0은 Windows 7과 XP에서 컴파일한 결과가 다른 황당한 문제가 발생할 때가 있음 [본문으로]
Trackback 0 Comment 3
  1. Favicon of http://un-i.tistory.com/ BlogIcon Un-i-que 2010.12.17 22:16 address edit & delete reply

    결국 manifest 문제였군요. Win7의 UAC 설정 자율화의 영향이고, UAC를 풀고 있던 제 컴퓨터에서 아무 장애 없이 작동한 것도 그 때문이고... ㅜㅠ

    • Favicon of http://zockr.tistory.com BlogIcon BLUEnLIVE 2010.12.17 22:19 address edit & delete

      저두요… 어허허허허.
      그런데, 사용하시는 분들의 반응을 보니 UAC를 완전 개방하고 쓰시는 분들이 의외로 많은 것 같습니다.
      정말로 소수의 사용자분들만 지적하셨어요. ㅎㅎㅎ

  2. Agatha 2011.03.31 20:43 address edit & delete reply

    저기 개발자님 저 2.3버젼 쓰는데 어떤 파일도 끌어놔도 안들어가지는데.. 이 글봐도 뭐가 뭔지 모르겠군요ㅜ 어떻게 해야하나요??