Настройка приложения для Windows

В Windows 8.1 и более поздних версиях функции GetVersion и GetVersionEx устарели. С Windows 10 функция VerifyVersionInfo также является устаревшей. Вы по-прежнему можете вызывать устаревшие функции, но если приложение специально не предназначено для Windows 8.1 или более поздней версии, функции возвращают Windows 8 версии (6.2).

Примечание

Функции GetVersion, GetVersionEx, VerifyVersionInfo и вспомогателя версий предназначены только для классических приложений. Универсальные приложения для Windows могут использовать свойство AnalyticsInfo.VersionInfo для журналов телеметрии и диагностики.

Чтобы приложение направлено на Windows 8.1 или более поздней версии, необходимо включить манифест приложения (исполняемого файла) для исполняемого файла приложения. Затем в <разделе совместимости> манифеста необходимо добавить элемент supportedOS> для каждой< версии Windows, которую вы хотите объявить, что поддерживает ваше приложение.

В следующем примере показан файл манифеста приложения, которое поддерживает все версии Windows от Windows Vista до Windows 11:

<!-- example.exe.manifest -->
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly manifestVersion="1.0" xmlns="urn:schemas-microsoft-com:asm.v1" xmlns:asmv3="urn:schemas-microsoft-com:asm.v3">
    <assemblyIdentity
        type="win32"
        name="Contoso.ExampleApplication.ExampleBinary"
        version="1.2.3.4"
        processorArchitecture="x86"
    />
    <description>Contoso Example Application</description>
    <compatibility xmlns="urn:schemas-microsoft-com:compatibility.v1">
        <application>
            <!-- Windows 10 and Windows 11 -->
            <supportedOS Id="{8e0f7a12-bfb3-4fe8-b9a5-48fd50a15a9a}"/>
            <!-- Windows 8.1 -->
            <supportedOS Id="{1f676c76-80e1-4239-95bb-83d0f6d0da78}"/>
            <!-- Windows 8 -->
            <supportedOS Id="{4a2f28e3-53b9-4441-ba9c-d69d4a4a6e38}"/>
            <!-- Windows 7 -->
            <supportedOS Id="{35138b9a-5d96-4fbd-8e2d-a2440225f93a}"/>
            <!-- Windows Vista -->
            <supportedOS Id="{e2011457-1546-43c5-a5fe-008deee3d3f0}"/> 
        </application>
    </compatibility>
    <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
        <security>
            <requestedPrivileges>
                <!--
                  UAC settings:
                  - app should run at same integrity level as calling process
                  - app does not need to manipulate windows belonging to
                    higher-integrity-level processes
                  -->
                <requestedExecutionLevel
                    level="asInvoker"
                    uiAccess="false"
                />   
            </requestedPrivileges>
        </security>
    </trustInfo>
</assembly>

Объявление поддержки Windows 8.1 или более поздней версии в манифесте приложения не будет иметь никакого влияния при запуске приложения в предыдущих операционных системах.

Приведенный выше манифест приложения также содержит <раздел trustInfo>, в котором указывается, как система должна относиться к нему в отношении контроля учетных записей (UAC). Добавление trustInfo не является обязательным, но настоятельно рекомендуется, даже если приложению не требуется определенное поведение, связанное с UAC. В частности, если вы вообще не добавите trustInfo , то для 32-разрядных версий приложения x86 будет применяться виртуализация файлов UAC, что позволяет выполнять записи в папки с правами администратора, такие как системные папки Windows, в случае сбоя, но перенаправляет их в папку VirtualStore для конкретного пользователя.