LoginSignup
29
30

More than 1 year has passed since last update.

Windows FormアプリをMSIXでパッケージ化・配布する

Last updated at Posted at 2021-06-13

MSIXについて

ClickOnceに変わる新しいアプリケーション配布の仕組みとして、MSIXがあります。
既存の.NET Frameworkで作成したアプリケーションでも、Windows アプリケーション パッケージ プロジェクトをソリューションに追加するだけで、容易にMSIXでパッケージ化することができます。

Docsに詳細な記載はありますが、実際の手順について記載します。
https://docs.microsoft.com/ja-jp/windows/msix/desktop/desktop-to-uwp-packaging-dot-net

MSIXの更新の仕組み

MSIXの更新の仕組みは、ClickOnceのように「毎回起動時に更新」ではありません。
AppX Deployment Service (AppXSVC)という、Microsoft Store アプリケーションを展開するためのサービスが不定期にチェックをかけてバックグラウンドで更新するため、更新の処理が一定以上進むまでは更新前のバージョンでアプリケーションが起動します。
従って、更新版をリリースしたのに、クライアントによっては2回くらい再起動しないと更新が反映されない事があります。
ClickOnceのようにアプリ起動時に「必ず」更新確認するやり方は別記事で紹介します。

MSIXのパッケージ化の手順

では、実際にMSIXでパッケージ化する手順について記載します。

プロジェクトの準備

  1. 通常のWindowsフォームアプリケーションやコンソールアプリケーションのソリューションに、「Windows アプリケーション パッケージ プロジェクト」を追加します。
    Proj01.png

  2. 追加された「Windows アプリケーション パッケージ プロジェクト」(以後、「WinAppPackagingプロジェクト」)のアプリケーションを右クリックし、「参照の追加」をクリックします。
    Proj02.png

  3. 既存のプロジェクトの一覧が表示されるので、パッケージに含めるプロジェクトを選択して【OK】を押下します。
    Proj03.png

  4. WinAppPackagingプロジェクトのプロパティを表示すると、ターゲットとなるWindows10のバージョンを指定できます。特に変える必要も無いかと思います。
    Proj04.png

  5. 次に、Package.appxmanifestをダブルクリックするとアプリ名等の設定ができます。
    Proj05.png
    Proj06.png
    「表示名」がスタートメニューやアプリの一覧に表示される名前です。
    Inst02_.png
    「パッケージ表示名」がインストール画面に表示される名前です。
    Inst01.png

パッケージ化

  1. 次に発行です。WinAppPackagingプロジェクトを右クリックし、「公開」→「アプリパッケージの作成」を選択します。
    Pack01.png

  2. 配布方法:そのままで【次へ】を押下します。
    Pack02.png

  3. 署名方法の選択:コードサイニング証明書を持っていればいずれかから選択、テスト的なものであれば【作成】を押してオレオレ証明書を作成します。
    Pack03_.png

  4. 証明書の準備ができたら、【次へ】を押下します。
    Pack04.png

  5. 出力場所を確認し、【次へ】を押下します。
    Pack05.png

  6. インストーラを配置するURLを入力し、【作成】を押下します。
    Pack06.png

  7. 以下の画面が表示されれば完了です。【閉じる】を押下し、「出力場所」に作成されたファイルを、「インストーラーの場所」に公開すれば他のPCからインストール可能な状態となります。
    Pack07.png

クライアントへのインストール

  1. 「インストーラーの場所」のURL(index.html)をブラウザで開き、【アプリを取得する】をクリックします。
    または、「ファイル名を指定して実行」で以下のようにappinstallerを実行すると直接インストーラを起動することができます。
ms-appinstaller:?source=https://**************/WinAppPackaging.appinstaller

Inst01.png

  1. 「アプリインストーラーを開きますか?」が表示されたら、【アプリインストーラーを開く】をクリックします。
    Inst02.png

  2. 「○○をインストールしますか?」で【インストール】をクリックします。
    Inst03C.png

  3. インストールが完了すると、アプリが起動します。
    Inst04.png

更新時の動き

クライアントにインストール後、新しいバージョンを「インストーラーの場所」に配置し、しばらくすると自動的に更新が走ります。
最初に記載したように、バックグラウンドで更新されるまでは古い(インストールされている)バージョンが起動します。
大体、クライアントが2回くらい再起動されないと更新されないように感じます。
更新が走った時、スタートメニューの項目の下にプログレスバーが表示されるので「更新された」というのがわかります。
更新の瞬間.gif

また、イベントビューワーで更新のログを確認する事も出来ます。
アプリケーションとサービスログ → Microsoft → Windows → AppXDeployment-Server
イベントビューアー.png

29
30
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
29
30