*.NETプログラミング研究 第55号 [#w3c1e7e1]

**.NET Tips [#h38fdadc]

***.NET Framework再頒布可能パッケージの中身を見てみる [#f2389a91]

これはTipというより、「解剖」という感じでしょうか。

.NET Framework再頒布可能パッケージはVersion 1.0が「dotnetredist.exe」、1.1が「dotnetfx.exe」というファイル名でマイクロソフトのサイトからダウンロードできます。

-[[.NET Framework 1.1 再頒布パッケージ>http://www.microsoft.com/downloads/details.aspx?FamilyID=262d25e3-f589-4842-8157-034d1e7cf3a3&DisplayLang=ja]]
-[[.NET Framework 1.0 再頒布パッケージ ダウンロード>http://www.microsoft.com/japan/msdn/netframework/downloads/sdk.asp]]

これらのファイルはCabの自己展開書庫ですので、アーカイバで展開することができます。実際に展開してみると、次のようなファイルが作成されます。

・.NET Framework 1.1再頒布可能パッケージ(dotnetfx.exe)を展開した時に作成されるファイル

#pre{{
ファイル名   サイズ(バイト) 製品バージョン
install.exe            98,304   1.1.4322.573
InstMsi.exe         1,707,856     2.0.2600.1
InstMsiW.exe        1,821,008     2.0.2600.0
netfx.msi           5,942,272              -
netfx1.cab         14,638,532              -
}}

・.NET Framework 1.0再頒布可能パッケージ(dotnetredist.exe)を展開した時に作成されるファイル

#pre{{
ファイル名   サイズ(バイト) 製品バージョン
dotnetfx.exe       22,702,664    1.0.3705.15
}}

・dotnetredist.exe内のdotnetfx.exeを展開した時に作成されるファイル

#pre{{
ファイル名   サイズ(バイト) 製品バージョン
install.exe            98,304     1.0.3705.0
InstMsi.exe         1,707,856     2.0.2600.1
InstMsiW.exe        1,821,008     2.0.2600.0
netfx.msi           5,245,952              -
netfx1.cab         13,754,653              -
}}

この内、InstMsi.exeとInstMsiW.exeはWindows Installer 2.0再頒布可能パッケージです。よって、dotnetfx.exeにはWindows Installer 2.0再頒布可能パッケージが含まれていることが分かります。(現在マイクロソフトからダウンロードできるWindows Installer 2.0 Redistributableファイルの製品バージョンは2.0.2600.2ですので、同じではありません。)

-[[Windows Installer 2.0 Redistributable for Windows NT 4.0 and 2000>http://www.microsoft.com/downloads/details.aspx?displaylang=en&FamilyID=4B6140F9-2D36-4977-8FA1-6F8A0F5DCA8F]]
-[[Windows Installer 2.0 Redistributable for Windows 95, 98, and Me>http://www.microsoft.com/downloads/details.aspx?displaylang=en&FamilyID=CEBBACD8-C094-4255-B702-DE3BB768148F]]

dotnetfx.exeを実行すると、ファイルを展開し、install.exeを実行します。install.exeはコンピュータにWindows Installer 2.0以上がインストールされているか調べ、されていなければ、InstMsi.exeまたはInstMsiW.exeにより、Windows Installer 2.0をインストールします。その後、netfx.msiを実行して.NET Frameworkをインストールします。

以上から、.NET FrameworkはMSIファイルによりインストールされ、またdotnetfx.exeとWindows Installer 2.0以前の再頒布可能パッケージを同時に配布するのは意味がないということが分かります。

参考:

-[[.NET Framework Version 1.1 再配布可能パッケージ テクニカル リファレンス>http://www.microsoft.com/japan/msdn/library/ja/jpdnnetdev/htm/dotnetfxref1_1.asp]]

***dotnetfx.exeのコマンドラインオプションを調べる [#ofe1d751]

MSDNの「.NET Framework 1.1 の再配布」によると、Dotnetfx.exeのサイレントインストールは、

dotnetfx.exe /q:a /c:"install /l /q"

というコマンドで実行されるとのことです。

-[[.NET Framework 1.1 の再配布>http://www.microsoft.com/japan/msdn/library/ja/jpdnnetdev/htm/redistdeploy1_1.asp]]

このコマンドの意味するところは何なのでしょうか?まず、「dotnetfx.exe /?」コマンドにより、dotnetfx.exeのコマンドラインオプションを調べてみます。その結果、次のような説明が表示されました。

#pre{{
/Q
    パッケージ処理の状況を一部表示しないモード
/T:<完全なパス>
    一時フォルダを指定
/C
    /Tと同時に指定した場合に、指定したフォルダのみにファイルを展開
/C:<Cmd>
    指定したインストールコマンドを無視
}}

つまり、「/Q」はサイレントモードを指定し、「/T」と「/C」では「/T」で指定したフォルダにファイルを展開し、「/C:<Cmd>」では展開後に実行するコマンドを指定(製作者により指定されたインストールコマンドを上書き)できるようです。

しかしこれでは上記の「/q:a /c:"install /l /q"」というコマンドラインの「/q:a」が何を意味するかは分かりません。実はdotnetfx.exeのコマンドラインオプションはこれだけではありません。

dotnetfx.exeのプロパティを表示すると、「説明」が「IExpress Setup」となっていることが分かります。つまりこのパッケージの作成には、IExpressが使われているのです。(dotnetredist.exeなどは「説明」が「Win32 キャビネット自己展開ツール」と表示されますが、これもIExpressで作成されたことを意味します。)IExpressとはWindows 2000、Windows XPにインストールされているCab書庫を作成するためのツールで、詳しくは、DOBON.NETの「VBに適したインストーラを探そう」などをご覧ください。

-[[VBに適したインストーラを探そう - 5.おまけのアーカイバ選び>http://dobon.net/vb/installer/installer5.html]]

IExpressパッケージに使用できるコマンドラインオプションについては、サポート技術情報の「IExpress ソフトウェア更新プログラム パッケージのコマンド ライン スイッチ」で説明されています。

-[[IExpress ソフトウェア更新プログラム パッケージのコマンド ライン スイッチ>http://support.microsoft.com/kb/197147/]]

ここで説明されているコマンドラインオプションを以下に引用させていただきます。

#prescroll(wrap=true){{
/q
    自動インストールを実行します (メッセージを一部表示しません)。
/q:u
    ユーザー非表示モードで実行します (ユーザーにいくつかのダイアログ ボックスが表示されます)。
/q:a
    管理者非表示モードで実行します (ユーザーにダイアログ ボックスが表示されません)。
/t:path
    ファイルの展開先フォルダを指定します。
/c
    インストールを実行せずにファイルの展開のみを行います。/t: path を指定していない場合は、展開先フォルダの入力を求められます。  
/c:path
    セットアップ .inf ファイルまたは .exe ファイルの UNC パスと名前を指定します。
/r:n
    インストール完了後にコンピュータを再起動しません。
/r:i
    再起動が必要な場合に、ユーザーにコンピュータの再起動を求めるメッセージを表示します (ただし、/q:a を使用している場合は除きます)。
/r:a
    インストール完了後にコンピュータを必ず再起動します。
/r:s
    インストール完了後、ユーザーにメッセージを表示せずにコンピュータを再起動します。
/n:v
    バージョン チェックを実行しません。パッケージのインストール時に以前のバージョンをすべて上書きします。
}}

これでようやくすべての意味が分かりました。「/q:a /c:"install /l /q"」は、管理者非表示モードで実行し、展開後「install /l /q」というコマンドを実行するという意味だということが分かります。

ところで、「install /l /q」の意味はなんでしょうか?早速「install /?」でinstall.exeのコマンドラインオプションを調べてみました。

#pre{{
/? または /h
    このダイアログ(使い方ダイアログ)
/u
    アンインストール
/l
    一時ディレクトリにnetfx.logを作成する
}}

これまた「/q」に対する説明に欠けていますが、これに関しては「.NET Framework Version 1.1 再配布可能パッケージ テクニカル リファレンス」で説明されています。

-[[.NET Framework Version 1.1 再配布可能パッケージ テクニカル リファレンス>http://www.microsoft.com/japan/msdn/net/deployment/dotnetfxref1_1.asp]]

その説明を以下に引用させていただきます。

#prescroll(wrap=true){{
/l
    セットアップ ログの netfx.log を %temp% ディレクトリに作成します。Dotnetfx.exe から返されるエラー コードは、このログに書き込まれます。
/q
    無人 インストール モードを指定します。セットアップ ユーザー インターフェイスの表示を抑止します。無人 インストールでは、Dotnetfx.exe の /q:a オプションも指定して、展開ユーザー インターフェイスを抑止する必要があります。
}}

つまり「install /l /q」では、一時フォルダにログを作成し、無人インストールモードを指定していることが分かります。

これでようやくすっきりしましたね。

補足:

.NET FrameworkのLanguage Pack、langpack.exeも「IExpress Setup」ですが、内蔵されているbootstrapperは「Install.exe」ではなく、「inst.exe」です。「inst.exe /?」により表示されるオプションの説明は、次のようなものです。

#pre{{
/? または /h
    このダイアログ(使い方ダイアログ)
/q
    UIを使用しない無人インストール
/qb
    プログレスバーを使用する無人セットアップ
/u
    アンインストール
/l
    一時ディレクトリにログを作成する
}}

Install.exeとinst.exeは非常に似ているため、Install.exeでも/qbオプションが使えるかもしれません。(未確認)

参考:

-[[Microsoft Windows インストーラ ツール の コマンド ライン スイッチ>http://support.microsoft.com/kb/227091/ja]]

***インストール前に.NET Frameworkをインストールする [#t67817d9]

.NETアプリケーションをMSIファイルで配布する時、インストール先のコンピュータに.NET Frameworkがインストールされていなければ、これが先にインストールされるようにする方法を紹介します。

***「Microsoft .NET Framework version 1.1 Setup.exe Bootstrapper Sample」を使った方法 [#ld11e93f]

まず、MSDNの「.NET Framework 1.1 配布ガイド」と「.NET Framework アプリケーション配布ガイド」(.NET Framework 1.0の場合)でその方法が説明されています。

-[[.NET Framework 1.1 配布ガイド>http://www.microsoft.com/japan/msdn/library/ja/jpdnnetdev/htm/dotnetframedepguid1_1.asp]]
-[[.NET Framework アプリケーション配布ガイド>http://www.microsoft.com/japan/msdn/library/ja/jpdnnetdev/htm/dotnetframedepguid.asp]]
-[[HOW TO: Visual Studio .NET デプロイメント プロジェクトの .NET Framework を配布します。>http://support.microsoft.com/kb/324733/ja]]

ここで紹介されている方法は、マイクロソフトが公開している「Microsoft .NET Framework version 1.1 Setup.exe Bootstrapper Sample」を使う方法です。(.NET Framework 1.0のBootstrapperはリンク先が見つからず、どこにあるのか分かりませんでした。)

-[[Microsoft .NET Framework version 1.1 Setup.exe Bootstrapper Sample>http://go.microsoft.com/fwlink/?LinkId=16426]]

以下にこの.NET Framework 1.1用のBootstrapperを使った場合の手順を簡単に紹介します。ここでは、インストールするMSIファイル(ここでは、「Setup1.msi」とする)と、「Microsoft .NET Framework Version 1.1 再頒布可能パッケージ」(dotnetfx.exe)、「Microsoft .NET Framework Version 1.1 日本語 Language Pack」(langpack.exe)はすでに用意されているものとします。

-[[Microsoft .NET Framework Version 1.1 再頒布可能パッケージ>http://www.microsoft.com/downloads/details.aspx?displaylang=ja&FamilyID=262D25E3-F589-4842-8157-034D1E7CF3A3]]
-[[Microsoft .NET Framework Version 1.1 日本語 Language Pack>http://www.microsoft.com/downloads/details.aspx?FamilyId=04DBAF2E-61ED-43F4-8D2A-CCB2BAB7B8EB&displaylang=ja]]

まず上記のリンクから「Microsoft .NET Framework version 1.1 Setup.exe Bootstrapper Sample」(NETFX1.1_bootstrapper.exe)をダウンロードし、書庫を展開します。すると、「setup.exe」と「settings.ini」の2つのファイルができます。

次に、settings.iniをテキストエディタで開き、適当な内容に変更します。最低限の設定は、次のようになります。

#pre{{
[Bootstrap]
Msi=Setup1.msi

[LangPacks]
1041
}}

まず、[Bootstrap]の「Msi」でインストールするMSIファイルを指定します。また、[LangPacks]で日本語のLanguage Packのインストールを指定します(Language Packのインストールが必要なければ、省略できます)。

このsettings.iniとsetup.exe、及びSetup1.msi、dotnetfx.exe、langpack.exeを同じフォルダに入れてsetup.exeを実行させると、望みの動作が実現します。

setup.exeを実行すると、「Application Setup」というタイトルの「To start Application Setup, click OK. To quit without installing, click Cancel.」というダイアログが表示されます。settings.iniを編集することでこのメッセージを変更できます。また、エラーダイアログのタイトル(通常は「Application Setup Error」)も変更できます。次にこれらを変更した例を示します。なお、Shift JISで保存してください。

#prescroll(wrap=true){{
[Bootstrap]
Msi=Setup1.msi
ProductName=マイアプリ
DialogText=「マイアプリ」のセットアップを開始するには「OK」を、インストールせずに終了するには「キャンセル」をクリックしてください。
CaptionText=マイアプリのセットアップ
ErrorCaptionText =マイアプリセットアップエラー

[LangPacks]
1041
}}

ProductNameにはアプリケーションの名前を指定します。これは、DialogText、CaptionText、ErrorCaptionTextが指定されていない時に、「Application Setup」に代わって使われます。

DialogTextには初めに表示されるダイアログのメッセージを、CaptionTextにはそのタイトルを指定します。ErrorCaptionTextにはエラーダイアログのタイトルを指定します。(ただし、エラーメッセージは英語です。)

さらにMSIファイルとdotnetfx.exe及びlangpack.exeを別のフォルダに置きたい時は、[Bootstrap]の「FxInstallerPath」でdotnetfx.exeとlangpack.exeのあるフォルダのパスを指定します。このパスは、絶対パスまたは相対パスを指定できます。例えば、dotnetfx.exeとlangpack.exeを「dotnetfx」というフォルダに入れた場合は、次のようにします。

#prescroll(wrap=true){{
[Bootstrap]
Msi=Setup1.msi
ProductName=マイアプリ
DialogText=「マイアプリ」のセットアップを開始するには「OK」を、インストールせずに終了するには「キャンセル」をクリックしてください。
CaptionText=マイアプリのセットアップ
ErrorCaptionText =マイアプリセットアップエラー
FxInstallerPath=dotnetfx

[LangPacks]
1041
}}

***「Microsoft Visual Studio .NET 2003 Bootstrapper Plug-In」を使用した方法 [#w27d271d]

マイクロソフトでは、「Microsoft Visual Studio .NET 2003 Bootstrapper Plug-In」というプラグインを配布しています。これを使用して、.NET Framework 1.1とMDAC 2.7を配布するインストーラを作成できます。

-[[Microsoft Visual Studio .NET 2003 Bootstrapper Plug-In>http://www.microsoft.com/downloads/details.aspx?FamilyID=627921a0-d9e7-43d6-a293-72f9c370bd19&displaylang=ja]]
-[[Visual Studio .NET Framework Bootstrapper Plug-in: Workspace Home>http://workspaces.gotdotnet.com/vsboot]]

このプラグインをインストール後、VS.NETのデプロイメントプロジェクトのプロパティで「ブートストラップ」を「Windowsインストーラブートストラップ」としてからビルドすることにより、出力されたMSIファイルと同じフォルダに、Setup.exe、Settings.ini、Config.ini、dotnetfx.exe、langpack.exeの5つのファイルが作成されます。これらすべてのファイルを配布し、インストールする時はこのSetup.exeを実行するようにすればよいわけです。

このプラグインはヘルプもなく、説明がほとんどないため、使用法がよく分かりません。よって、ここでの説明はあくまで推測でしかないことをご了承ください。

まず、ダイアログに表示されるメッセージを変更するには、Config.iniを編集するようです。また、MSIファイルのパス、dotnetfx.exeのパス、langpack.exeのパスをSettings.iniで指定できるようです。

さて、MDACに関しては、このままではインストールされません(必要に応じてMDACがインストールされる設定になるという報告もあるようですが、確認できませんでした)。MDACをインストールする時は、Settings.iniの「MdacVersion」にMDACのバージョンを設定し、「BootstrapMdac」をtrueにしてから、Setup.exeと同じフォルダにmdac_typ.exeをコピーします(mdac_typ.exeは、「<Program Filesフォルダ>\Microsoft Visual Studio .NET 2003 Bootstrapper Plug-in\1041」にあります)。

***「Enhanced .NET Bootstrap Setup」を使用した方法 [#laccaabd]

.NET Frameworkには、Internet Explore 5.01以上がインストールされていることが必要です。「.NET Framework 1.1 再配布可能パッケージの必要条件」によると、Windows NT 4.0と98にはIE4.01が、Windows 98 SEにはIE5.00があらかじめインストールされているため、これらのOSでは5.01以降のIEをインストールする必要があるかもしれません。

-[[.NET Framework 1.1 再配布可能パッケージの必要条件>http://www.microsoft.com/japan/msdn/library/ja/jpdnnetdev/htm/NETFx1Redistreq1_1.asp]]

「The Code Project」の「Enhanced .NET Bootstrap Setup」では、.NET Framework、Language Pack、MDACの他に、IE 6.01とWindows Installerもインストールできるブートストラップが公開されています。

-[[The Code Project - Enhanced .NET Bootstrap Setup>http://www.codeproject.com/managedcpp/DotNetSetup.asp]]

設定は、「settings.ini」で行います。settings.iniの書き方については上記URLで説明されていますが、以下に簡単に説明します。

#prescroll(wrap=true){{
Msi
    インストールするMSIファイルのパスを指定します。
ProductName
    製品名を指定します。
FxInstallerPath
    Dotnetfx.exeのあるフォルダのパスを指定します。
IEInstallerPath
    IE 6.01パッケージ(ie6setup.exe)のあるフォルダのパスを指定します。
MSIInstallerPath
    Windows Installer 2.0パッケージ(InstMsiW.exeとInstMsiA.exe)のあるフォルダのパスを指定します。
MDACInstallerPath
    mdac_typ.exeのあるフォルダのパスを指定します。
MDACVersion
    MDACのバージョンを指定します。
.NetVersion
    .NET Frameworkのバージョン(「v1.0」か「v1.1」)を指定します。
MSDEInstallerPath
    MSDE(SQL Server 2000 Desktop Engine)インストーラ(setup.exe)のあるフォルダのパスを指定します。
MSDEParams
    MSDEパラメータを指定します。
}}

この他に「LanguageDirectory」も使われているようで、「<Windowsディレクトリ>\Microsoft.NET\(.NET Frameworkのバージョン)\(「LanguageDirectory」で指定された文字列)」というフォルダを探し、なければ.NET Frameworkをインストールするという処理をしているようです。(サンプルでは、「LanguageDirectory=jpn」となっていますが、少なくとも私の環境では、「jpn」ではなく「JA」のようです。)

この「Enhanced .NET Bootstrap Setup」ですが、私の環境で試した限りでは、正常に動作しませんでした。

まず、.NET Frameworkがインストールされていても、「Could not find the .Net Version Number in the registry」というエラーがでて、.NET Frameworkをインストールするように指定します。どうやらこのBootstrapでは、dotnetfx.exeのファイルバージョンのビルド番号をこれがインストールする.NET Frameworkのビルド番号と判断して、レジストリの「HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\.NETFramework\policy\(「.NetVersion」の値)」にこのビルド番号と同じ値が存在しているか調べ、なければ.NET Frameworkをインストールするようにしているようですが、そのビルド番号が正しく取得できていないため、正しく判断できていないようです。

また、Windows Installerのインストールの判断も正しくないようです。インストールされているWindows Installerのバージョンがきっちり2であるか調べ、そうでなければWindows Installerをインストールするようにしているようで、バージョン3がインストールされていても、Windows Installerをインストールしようとします。(それ以前の問題として、「.NET Framework再頒布可能パッケージの中身を見てみる」で紹介したように、そもそもWindows Installer 2.0をインストールする必要があるかも疑問です。)

「Enhanced .NET Bootstrap Setup」はソースが公開されているため、修正は可能でしょう。(メッセージは英語ですが、リソースを書き換えることにより、日本語表示できそうです。)

***「dotNetInstaller - Setup Bootstrapper for .NET Application」を使用した方法 [#x46358ce]

ここまでいろいろなBootstrapを紹介してきましたが、これらはすべてすでに決められたパッケージを、すでに決められた条件で判断してインストールするというものでした。

最後に紹介する「dotNetInstaller - Setup Bootstrapper for .NET Application」では、インストールするパッケージと、インストールする条件を自由にカスタマイズすることができます。よって、.NET FrameworkやMDACだけでなく、NT4のSP6aや、J#の再頒布可能パッケージのインストールも指定できます。

-[[dotNetInstaller - Setup Bootstrapper for .NET Application>http://www.devage.com/dotNetInstaller/dotNetInstaller.html]]

dotNetInstallerでは、まずInstaller Editorにより設定ファイル(XMLファイル)を作成する必要があります。設定ファイルは、同梱されている「StandaloneSetup」のサンプルが参考になります。サンプルにはイタリア語の「Setup Configuration」がありますが、まずはこれを日本語(LCID=1041)に変更して使用するとよいでしょう。

dotNetInstallerのBootstrapperを実行するには、dotNetInstaller.exeと同じフォルダに設定ファイル「configuration.xml」と、バナーに使用する画像、unicows.dllを入れ、さらに設定で指定された場所にパッケージを用意した状態で、dotNetInstaller.exeを実行します。Installer Editorのメニュー「File」の「Create Exe」によりExeファイルを作成したときは、そのExeファイルに設定とバナーが埋め込まれますので、設定ファイルとバナー画像は必要なくなります。

設定の書き方について、もう少し補足しておきましょう。

サンプルのイタリア語のSetup Configurationでは、.NET Frameworkのインストールは行っていますが、Language Packのインストールは行っていないようです。そこで試しに、.NET Frameworkの日本語Language Packをインストールする設定を加えることにしましょう。(ここでは、LCIDが1041のSetup Configurationがあるものとします。)

まず「install:1041」の項目を右クリックし、「Add」から「Command Component」を選択します。作成された「Command Component」の設定は、

#prescroll(wrap=true){{
command
    "#APPPATH\SupportFiles\dotNet1.1\Japanese\LangPack.exe" /q:a /c:"inst /l /q"
description
    Microsoft .NET Framework Version 1.1 日本語 Language Pack
note
    日本語 - Standard - .NET Framework Version 1.1 日本語 Language Pack
}}

とします。

次にこのCommand Componentが実行される条件を指定します。日本語Language Packがインストールされているか調べる方法については、「.NET Framework 1.1 の再配布」で説明されています。これによると、レジストリの「HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\NET Framework Setup\NDP\v1.1.4322\1041」に「Install(DWORD value = 1)」という値があれば、すでにインストールされていると判断できるようです。

-[[.NET Framework 1.1 の再配布>http://www.microsoft.com/japan/msdn/library/ja/jpdnnetdev/htm/redistdeploy1_1.asp]]

上記で作成したCommand Component項目を右クリックし、「Add」の「Installed Check Registry」を選択します。そして、次のように項目を埋めます。

#pre{{
comparison
    match
fieldname
    Install
fieldtype
    REG_DWORD
fieldvalue
    1
path
    SOFTWARE\Microsoft\NET Framework Setup\NDP\v1.1.4322\1041
}}

これで日本語Language Packがインストールされていない時にインストールされる設定が追加されました。

ただ問題は、その位置です。今の状態では、アプリケーションのMSIファイルの後にLanguage Packがインストールされることになります。Command Componentの位置を変更するのは、Installer Editorでは無理のようです。よって、設定ファイルをテキストエディタで開き、手作業で修正する必要があります(メニューの「File」-「Edit With Notepad」により、メモ帳で開くことができます)。

同様の方法で、J#の再頒布可能パッケージとLanguage Packをインストールする設定も追加することができます。これらがインストールされているか調べる方法も、「.NET Framework 1.1 の再配布」で説明されています。

参考までに、以上のように作成した設定を、日本語のSetup Configurationの部分のみ、以下に示します。(一行が長いため、途中で改行しています。)いい加減なものですので、参考だけにしてください。

#prescroll(wrap=true){{
<configuration type="install" lcid="1041" dialog_caption="アプリケーションのセットアップ" dialog_message="このアプリケーションをインストールするには、次のコンポーネントのインストールが必要です。" dialog_bitmap="#APPPATH\banner.bmp" install_caption="インストール" cancel_caption="閉じる" status_installed=" (インストール済)" status_notinstalled="" failed_exec_command_continue="%s のインストールに失敗しました。続行しますか?" installation_completed="アプリケーションのインストールに成功しました!" installing_component_wait="%s をインストールしています。しばらくお待ちください..." reboot_required="インストールを続けるにはコンピュータを再起動する必要があります。今すぐ再起動しますか?" advanced_caption="選択変更" dialog_selector_cancel="キャンセル" dialog_selector_caption="コンポーネントリスト" dialog_selector_message="インストールするコンポーネントを選択してください。" dialog_selector_ok="OK" dialog_otherinfo_caption="" dialog_otherinfo_link="" complete_command="" auto_close_if_installed="True">
  <components>
    <component os_filter_greater="29" os_filter_smaller="40" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Windows NT 4 Service Pack 6a" note="Neutral - Standard - Windows NT 4 Service Pack 6a High Encryption x86" command="&quot;#APPPATH\SupportFiles\ServicePacks\NT4_SP6a\HighEncryption_x86\Network\Japanese\sp6i386.exe&quot;" />
    <component os_filter_greater="44" os_filter_smaller="59" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Windows 2000 Service Pack 4" note="日本語 - Standard - Windows 2000 Sp4 Full (Sp3 Required)" command="&quot;#APPPATH\SupportFiles\ServicePacks\2000_SP4\Network\Japanese\W2KSP4_ja.EXE&quot;" />
    <component os_filter_greater="" os_filter_smaller="80" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft Internet Explorer 6 Sp1" note="日本語 - Standard - Internet Explorer 6Sp1 English (IE 5.01 Required)" command="&quot;#APPPATH\SupportFiles\InternetExplorer6.0Sp1\Japanese\ie6setup.exe&quot;">
      <installedcheck type="check_registry_value" path="SOFTWARE\Microsoft\Internet Explorer" fieldname="Version" fieldvalue="5.00.2920.0000" fieldtype="REG_SZ" comparison="version" />
    </component>
    <component os_filter_greater="14" os_filter_smaller="90" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft Data Access Components 2.8" note="日本語 - Standard - MDAC 2.8 for Win98, ME, NT4, 2000 and XP. Quit mode." command="&quot;#APPPATH\SupportFiles\MDAC2.8\Japanese\Win_98_ME_NT_2000_XP\MDAC_TYP.EXE&quot; /q:a /c:&quot;dasetup.exe /q&quot;">
      <installedcheck type="check_registry_value" path="SOFTWARE\Microsoft\DataAccess" fieldname="Version" fieldvalue="2.60.0.0" fieldtype="REG_SZ" comparison="version" />
    </component>
    <component os_filter_greater="4" os_filter_smaller="25" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft JET 4.0 Sp8" note="日本語 - Standard - Jet 4.0 Sp8 for 95 and 98" command="&quot;#APPPATH\SupportFiles\Jet40Sp8\Japanese\95_98_NT4\Jet40SP8_9xNT.exe&quot; /Q">
      <installedcheck type="check_file" filename="#SYSTEMPATH\Msjet40.dll" fileversion="4.0.8015.0" comparison="version" />
    </component>
    <component os_filter_greater="29" os_filter_smaller="41" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft JET 4.0 Sp8" note="日本語 - Standard - Jet 4.0 Sp8 for NT4" command="&quot;#APPPATH\SupportFiles\Jet40Sp8\Japanese\95_98_NT4\Jet40SP8_9xNT.exe&quot; /Q">
      <installedcheck type="check_file" filename="#SYSTEMPATH\Msjet40.dll" fileversion="4.0.8015.0" comparison="version" />
    </component>
    <component os_filter_greater="44" os_filter_smaller="66" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft JET 4.0 Sp8" note="日本語 - Standard - Jet 4.0 Sp8 for 2000" command="&quot;#APPPATH\SupportFiles\Jet40Sp8\Japanese\2000\Windows2000-KB829558-x86-JPN.exe&quot; /quiet">
      <installedcheck type="check_file" filename="#SYSTEMPATH\Msjet40.dll" fileversion="4.0.8015.0" comparison="version" />
    </component>
    <component os_filter_greater="24" os_filter_smaller="26" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft JET 4.0 Sp8" note="日本語 - Standard - Jet 4.0 Sp8 for ME" command="&quot;#APPPATH\SupportFiles\Jet40Sp8\Japanese\ME\jet40sp8_Wme.exe&quot; /Q">
      <installedcheck type="check_file" filename="#SYSTEMPATH\Msjet40.dll" fileversion="4.0.8015.0" comparison="version" />
    </component>
    <component os_filter_greater="89" os_filter_smaller="91" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft JET 4.0 Sp8" note="日本語 - Standard - Jet 4.0 Sp8 for Server2003" command="&quot;#APPPATH\SupportFiles\Jet40Sp8\Japanese\Server2003\windowsserver2003-kb829558-x86-jpn.exe&quot; /quiet">
      <installedcheck type="check_file" filename="#SYSTEMPATH\Msjet40.dll" fileversion="4.0.8015.0" comparison="version" />
    </component>
    <component os_filter_greater="74" os_filter_smaller="83" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft JET 4.0 Sp8" note="日本語 - Standard - Jet 4.0 Sp8 for XP" command="&quot;#APPPATH\SupportFiles\Jet40Sp8\Japanese\XP\windowsxp-kb829558-x86-jpn.exe&quot; /quiet">
      <installedcheck type="check_file" filename="#SYSTEMPATH\Msjet40.dll" fileversion="4.0.8015.0" comparison="version" />
    </component>
    <component os_filter_greater="" os_filter_smaller="45" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="True" description="Microsoft .NET Framework 1.1" note="日本語 - Standard - .NET Framework 1.1 for all OS before Win2000, 要再起動" command="&quot;#APPPATH\SupportFiles\dotNet1.1\Japanese\dotnetfx.exe&quot; /q:a /c:&quot;install /l /q&quot;">
      <installedcheck type="check_registry_value" path="SOFTWARE\Microsoft\NET Framework Setup\NDP\v1.1.4322" fieldname="Install" fieldvalue="1" fieldtype="REG_DWORD" comparison="match" />
    </component>
    <component os_filter_greater="44" os_filter_smaller="90" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft .NET Framework 1.1" note="日本語 - Standard - .NET Framework 1.1 for Windows 2000 and Windows XP" command="&quot;#APPPATH\SupportFiles\dotNet1.1\Japanese\dotnetfx.exe&quot; /q:a /c:&quot;install /l /q&quot;">
      <installedcheck type="check_registry_value" path="SOFTWARE\Microsoft\NET Framework Setup\NDP\v1.1.4322" fieldname="Install" fieldvalue="1" fieldtype="REG_DWORD" comparison="match" />
    </component>
    <component os_filter_greater="" os_filter_smaller="" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft .NET Framework Version 1.1 日本語 Language Pack" note="日本語 - Standard - .NET Framework Version 1.1 日本語 Language Pack" command="&quot;#APPPATH\SupportFiles\dotNet1.1\Japanese\LangPack.exe&quot; /q:a /c:&quot;inst /l /q&quot;">
      <installedcheck type="check_registry_value" path="SOFTWARE\Microsoft\NET Framework Setup\NDP\v1.1.4322\1041" fieldname="Install" fieldvalue="1" fieldtype="REG_DWORD" comparison="match" />
    </component>
    <component os_filter_greater="" os_filter_smaller="" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft Visual J# .NET Version 1.1" note="日本語 - Standard - Microsoft Visual J# .NET Version 1.1" command="&quot;#APPPATH\SupportFiles\dotNet1.1\Japanese\vjredist.exe&quot; /q:a /c:&quot;inst /l /q&quot;">
      <installedcheck type="check_registry_value" path="Software\Microsoft\Visual JSharp Setup\Redist\v1.1.4322" fieldname="Install" fieldvalue="1" fieldtype="REG_DWORD" comparison="match" />
    </component>
    <component os_filter_greater="" os_filter_smaller="" os_filter_lcid="" type="cmd" installcompletemessage="" mustreboot="False" description="Microsoft Visual J# .NET Version 1.1 再頒布可能パッケージ Language Pack" note="日本語 - Standard - Microsoft Visual J# .NET Version 1.1 再頒布可能パッケージ Language Pack" command="&quot;#APPPATH\SupportFiles\dotNet1.1\Japanese\vjredist-LP.exe&quot; /q:a /c:&quot;inst /l /q&quot;">
      <installedcheck type="check_registry_value" path="Software\Microsoft\Visual JSharp Setup\Redist\v1.1.4322\1041" fieldname="Install" fieldvalue="1" fieldtype="REG_DWORD" comparison="match" />
    </component>
    <component os_filter_greater="" os_filter_smaller="" os_filter_lcid="" type="msi" installcompletemessage="" mustreboot="False" description="SampleApp 1.0.0.0" note="" package="#APPPATH\SampleApp.msi" cmdparameters="">
      <installedcheck type="check_registry_value" path="SOFTWARE\MyCompany\SampleApp\1.0.0.0" fieldname="Installed" fieldvalue="1" fieldtype="REG_DWORD" comparison="match" />
    </component>
  </components>
</configuration>
}}

dotNetInstallerの凄い所はこれだけではありません。dotNetInstallerでは、必要なパッケージをインターネットからダウンロードしてインストールすることもできるのです。さらに、bootstrapperのみをWebに公開し、残りのすべてのファイルは必要に応じてダウンロードしてインストールするということまでできてしまいます。この方法に関しては、dotNetInstallerのサイトの「How to create a Web Setup to install .NET Framework and your msi setup」をご覧ください。

ただし、私が試したところでは、ダウンロードしたファイルはインストール終了後も削除されないようです。

***最後に [#o4a95843]

ここで紹介したbootstrapperは、ユーザーがEXEファイルを無視して、MSIファイルを直接実行してしまったら全く意味がありません。これを防ぐには、すべてのファイルを自己展開書庫にまとめ、この自己展開書庫を実行した時に自動的にbootstrapperを実行するようにする方法があります。このような書庫を作成するのに適したアーカイバについては、DOBON.NETの「おまけのアーカイバ選び」をご覧ください。

-[[DOBON.NET - 5.おまけのアーカイバ選び>http://dobon.net/vb/installer/installer5.html]]

また、MSIファイルが直接実行されたとしても、必要なソフトウェアがコンピュータにインストールされていなければ実行できないように、適当な起動条件を追加したほうがよいかもしれません。例えば、MDAC 2.6以降がインストールされていることを起動条件とする方法に関しては、「Visual Studio .NET 2003 による .NET Framework の再配布」で紹介されています。

-[[Visual Studio .NET 2003 による .NET Framework の再配布>http://www.microsoft.com/japan/msdn/library/ja/jpdnnetdev/htm/vsredistdeploy1_1.asp]]

//これより下は編集しないでください
#pageinfo(,2010-03-17 (水) 03:29:19,DOBON!,2010-03-17 (水) 04:00:58,DOBON!)
[ トップ ]   [ 新規 | 子ページ作成 | 一覧 | 単語検索 | 最終更新 | ヘルプ ]