Windows バージョン確認

OS のバージョンは、Windows 10 OS リリースでインクリメントされました。 つまり、Windows 10の内部バージョン番号も 10.0 に変更されています。 Microsoft はこれまでと同様に、OS のバージョン変更後のアプリケーションとデバイスの互換性を維持するために全力を尽くしています。 ほとんどのアプリ カテゴリ (カーネル依存関係なし) の場合、この変更はアプリの機能に悪影響を与えず、既存のアプリは引き続きWindows 10で正常に動作します。

症状

この変更の影響はアプリ固有です。 つまり、OS のバージョンを厳密にチェックするアプリは大きいバージョン番号を取得します。その結果、次の 1 つ以上の状況が発生する場合があります。

  • アプリ インストーラーでアプリをインストールできず、アプリを開始できない場合があります。
  • アプリが不安定になる可能性またはクラッシュする可能性があります。
  • アプリでエラー メッセージが生成されても、アプリは正しく機能し続ける場合があります。

一部のアプリでは、バージョン チェックを実行して、ユーザーに警告を渡します。 ただし、(ドライバーで、または検出を回避するためのカーネル モードで) バージョン チェックに非常に緊密にバインドされているアプリがあります。 このような場合、正しくないバージョンが見つかると、アプリは失敗します。 バージョン チェックではなく、次のいずれかのアプローチをお勧めします。

  • アプリが特定の API 機能に依存している場合は、正しい API バージョンをターゲットにしてください。
  • NTDDI (NT デバイス ドライバー インターフェイス) のバージョン番号は、API のターゲット機能が変更された場合にのみインクリメントされます。 機能チームによって作成された APISet またはその他の公開されている API を使用して変更を検出し、一部の機能または修正プログラムのプロキシとしてバージョンを使用しないことを確認します。 仕様変更があり、しかも適切なチェックが公開されていない場合、それはバグです。
  • レジストリ、ファイル バージョン、オフセット、カーネル モード、ドライバーなどの方法で、アプリが奇数の方法でバージョンをチェックしないようにします。 アプリで絶対にバージョンを確認する必要がある場合は、メジャー、マイナー、ビルド番号を返す GetVersion API を使用します。
  • GetVersion API または VerifyVersionInfo などの他のバージョン ヘルパー関数を使用している場合は、Windows 8.1以降、この API の動作が変更されていることに注意してください。 詳細については 、API ドキュメント を参照してください。
  • マルウェア対策やファイアウォールなどのアプリを所有している場合は、通常のフィードバック チャネルと Windows Insider プログラムを介して作業する必要があります。

アプリ マニフェスト

アプリ マニフェストの例を次に示します。

<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=SXS_ASSEMBLY_NAME
        version=SXS_ASSEMBLY_VERSION
        processorArchitecture=SXS_PROCESSOR_ARCHITECTURE
    />
    <description> my app exe </description>
    <trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
        <security>
            <requestedPrivileges>
                <requestedExecutionLevel
                    level="asInvoker"
                    uiAccess="false"
                />   
            </requestedPrivileges>
        </security>
    </trustInfo>
    <compatibility xmlns="urn:schemas-microsoft-com:compatibility.v1"> 
        <application> 

      * <!-- Windows 10 --> 
      * <supportedOS Id="{8e0f7a12-bfb3-4fe8-b9a5-48fd50a15a9a}"/>
            <!-- Windows 8.1 -->
            <supportedOS Id="{1f676c76-80e1-4239-95bb-83d0f6d0da78}"/>
            <!-- Windows Vista -->
            <supportedOS Id="{e2011457-1546-43c5-a5fe-008deee3d3f0}"/> 
            <!-- Windows 7 -->
            <supportedOS Id="{35138b9a-5d96-4fbd-8e2d-a2440225f93a}"/>
            <!-- Windows 8 -->
            <supportedOS Id="{4a2f28e3-53b9-4441-ba9c-d69d4a4a6e38}"/>
        </application> 
    </compatibility>
</assembly>

ソースに次の変数を追加します。

  • SXS_MANIFEST_RESOURCE_ID=1
  • SXS_MANIFEST=foo.manifest
  • SXS_ASSEMBLY_NAME=Microsoft.Windows.Foo
  • SXS_ASSEMBLY_VERSION=1.0
  • SXS_ASSEMBLY_LANGUAGE_INDEPENDENT=1
  • SXS_MANIFEST_IN_RESOURCES=1

Windows 10の場合、上の 2 行にアスタリスク (*) が付いています。これは、OS のWindows 10 バージョンのアプリケーションを正確にターゲットにする方法を示しています。 以前のバージョンの Windows OS で実行する場合、Windows 10の.exeをマニフェストしても影響はありません。 既に定義されている場合は、これを .rc ファイルに追加することもできます。 trustInfo の追加は必須ではありませんが、強くお勧めします。 これにより、OS がWindows 10かWindows 8.1かに関係なく、.exeは常に正しいバージョンを取得できます。

リソース