從命令列建置 ClickOnce 應用程式
在 Visual Studio 中,您可以從命令列建置專案,即使專案是在整合式開發環境 (IDE) 中建立的。 事實上,您可以在只安裝 .NET Framework 的另一部電腦上,重新建置以 Visual Studio 所建立的專案。 這可讓您使用自動化處理序 (例如在集中建置實驗室,或使用超越建置專案本身範圍的進階指令碼技術),重新產生組建。
使用 MSBuild 重新產生 ClickOnce 應用程式部署
當您在命令列叫用 msbuild /target:publish,它會告訴 MSBuild 系統,建置專案並在發行資料夾中建立 ClickOnce 應用程式。 這相當於在 IDE 中選取 [發行] 命令。
這個命令會執行 msbuild.exe,它位於 Visual Studio 命令提示字元環境中的路徑。
"target" 向 MSBuild 指示如何處理命令。 主要目標為「建置」目標和「發行」目標。 建置目標相當於在 IDE 中選取 [建置] (或按 F5) 命令。 如果您只要建置專案,可以輸入 msbuild,完成此作業。 因為建置目標是所有由 Visual Studio 所產生專案的預設目標,所以這個命令有作用。 這表示您不必明確指定建置目標。 因此,輸入 msbuild 與輸入 msbuild /target:build 會執行相同作業。
/target:publish 命令告訴 MSBuild,叫用發行目標。 發行目標相依於建置目標。 這表示發行作業是建置作業的超集。 例如,如果您變更其中一個 Visual Basic 或 C# 原始程式檔,則發行作業會自動重新建置對應的組件。
如需使用 Mage.exe 命令列工具建立 ClickOnce 資料清單,產生完整 ClickOnce 部署的詳細資訊,請參閱逐步解說:手動部署 ClickOnce 應用程式。
使用 MSBuild 建立和建置基本的 ClickOnce 應用程式
若要建立和發行 ClickOnce 專案
從 [檔案] 功能表中,按一下 [新增專案]。 [新增專案] 對話方塊隨即出現。
選取 [Windows 應用程式],並為它命名為 CmdLineDemo。
從 [建置] 功能表中,按一下 [發行] 命令。
這個步驟可確保專案正確設定為產生 ClickOnce 應用程式部署。
[發行精靈] 隨即出現。
在 [發行精靈] 中,按一下 [完成]。
Visual Studio 隨即會產生和顯示名稱為 Publish.htm 的預設 Web 網頁。
儲存專案,並記下儲存專案的資料夾位置。
上面的步驟會建立 ClickOnce 專案,這個專案已經第一次發行。 現在您可以在 IDE 以外重新產生組建。
若要從命令列重新產生組建
結束 Visual Studio。
從 Windows [開始] 功能表,依序按一下 [所有程式]、[Microsoft Visual Studio]、[Visual Studio Tools] 和 [Visual Studio 命令提示字元]。 這應該會開啟一個命令提示字元,其位置便在目前使用者的根資料夾中。
在 [Visual Studio 命令提示字元],將目前目錄切換到前面剛建置好的專案位置。 例如,輸入 chdir My Documents\Visual Studio\Projects\CmdLineDemo。
若要移除上面<若要建立和建置 ClickOnce 專案>中產生的現有檔案,請輸入 rmdir /s publish。
這個步驟是選擇性,但這個動作會確保所有新檔案都是由此命令列組建產生的。
輸入 msbuild /target:publish。
上面的步驟將會在專案中名稱為 [Publish] 的子資料夾,產生完整的 ClickOnce 應用程式部署。 CmdLineDemo.application 是 ClickOnce 部署資訊清單。 資料夾 CmdLineDemo_1.0.0.0 包含檔案 CmdLineDemo.exe 和 CmdLineDemo.exe.manifest (ClickOnce 應用程式資訊清單)。 Setup.exe 是啟動載入器 (Bootstrapper),預設為安裝 .NET Framework。 DotNetFX 資料夾包含 .NET Framework 的可轉散發套件。 這些就是透過 Web、UNC 或 CD/DVD 部署應用程式所需的完整檔案集。
發行屬性
當您用以上的程序發行應用程式時,[發行精靈] 會將下列屬性插入專案檔。 這些屬性直接影響 ClickOnce 應用程式的產生方式。
CmdLineDemo.vbproj / CmdLineDemo.csproj:
<AssemblyOriginatorKeyFile>WindowsApplication3.snk</AssemblyOriginatorKeyFile>
<GenerateManifests>true</GenerateManifests>
<TargetZone>LocalIntranet</TargetZone>
<PublisherName>Microsoft</PublisherName>
<ProductName>CmdLineDemo</ProductName>
<PublishUrl>https://localhost/CmdLineDemo</PublishUrl>
<Install>true</Install>
<ApplicationVersion>1.0.0.*</ApplicationVersion>
<ApplicationRevision>1</ApplicationRevision>
<UpdateEnabled>true</UpdateEnabled>
<UpdateRequired>false</UpdateRequired>
<UpdateMode>Foreground</UpdateMode>
<UpdateInterval>7</UpdateInterval>
<UpdateIntervalUnits>Days</UpdateIntervalUnits>
<UpdateUrlEnabled>false</UpdateUrlEnabled>
<IsWebBootstrapper>true</IsWebBootstrapper>
<BootstrapperEnabled>true</BootstrapperEnabled>
您可以在命令列覆寫這些屬性,而不需變更專案檔本身。 例如,下列將會建置不含啟動載入器的 ClickOnce 應用程式部署:
msbuild /target:publish /property:BootstrapperEnabled=false
在 Visual Studio 中,從 [專案設計工具] 的 [發行]、[安全性] 和 [簽章] 屬性頁面,控制發行屬性。 以下是發行屬性的描述,以及在應用程式設計工具的各個屬性頁中如何設定屬性的指示:
- AssemblyOriginatorKeyFile 決定簽署 ClickOnce 應用程式資訊清單所使用的金鑰檔。 這個金鑰也可以用來簽署組件的強式名稱。 在 [專案設計工具] 的 [簽章] 頁面中,設定這個屬性。
下列屬性在 [安全性] 頁中設定:
[啟用 ClickOnce 安全性設定] 可決定是否產生 ClickOnce 資訊清單。 最初建立專案時,產生 ClickOnce 資訊清單的功能預設為關閉。 當您第一次發行時,精靈會自動開啟這個旗標。
TargetZone 決定發出給 ClickOnce 應用程式資訊清單的信任層級。 可能值為 "Internet"、"LocalIntranet" 和 "Custom"。 Internet 和 LocalIntranet 將會造成預設權限集發出至 ClickOnce 應用程式資訊清單。 LocalIntranet 為預設值,基本上表示完全信任。 Custom 指定只有基底 app.manifest 檔案中明確指定的權限,才會發出至 ClickOnce 應用程式資訊清單。 app.manifest 檔案是部分資訊清單檔案,只包含信任資訊定義。 它是隱藏檔案,當您在 [安全性] 頁面中設定權限時,便會自動加入至專案。
下列屬性在 [發行] 頁面中設定:
PublishUrl 是應用程式在 IDE 中發行時的目標位置。 如果未指定 InstallUrl 或 UpdateUrl 屬性,就會將它插入 ClickOnce 應用程式資訊清單。
ApplicationVersion 指定 ClickOnce 應用程式的版本。 這是四碼版本號碼。 如果最後一碼是 "*",則在建置時間 ApplicationRevision 會取代資訊清單中所插入的值。
ApplicationRevision 會指定修訂。 這是整數,每次您在 IDE 發行時,這個整數會累加。 請注意,對於在命令列執行的組建,它不會自動累加。
Install 可以判斷應用程式是安裝的應用程式還是從 Web 執行的應用程式。
InstallUrl (未顯示) 是使用者安裝應用程式的來源位置。 如果指定,這個值就會燒錄至 setup.exe 啟動載入器 (如果已啟用 IsWebBootstrapper 屬性)。 如果未指定 UpdateUrl,也會將此值插入應用程式資訊清單。
SupportUrl (未顯示) 是 [新增或移除程式] 對話方塊中已安裝程式的連結位置。
下列屬性在 [應用程式更新] 對話方塊 (從 [發行] 頁存取) 中設定。
UpdateEnabled 指出應用程式是否應該檢查更新檔。
UpdateMode 指定前景更新或背景更新。
UpdateInterval 指定應用程式應該檢查更新檔的頻率。
UpdateIntervalUnits 指定 UpdateInterval 值的單位:小時、天數或週數。
UpdateUrl (未顯示) 是應用程式將接收更新檔的來源位置。 如果指定,這個值會插入應用程式資訊清單。
下列屬性在 [發行選項] 對話方塊 (從 [發行] 頁面存取) 中設定。
PublisherName 指定發行者的名稱,當安裝或執行應用程式時,它會顯示在提示中。 在安裝的應用程式案例中,它也用來指定 [開始] 功能表上的資料夾名稱。
ProductName 指定產品的名稱,當安裝或執行應用程式時,它會顯示在提示中。 在安裝的應用程式案例中,它也用來指定 [開始] 功能表上的捷徑名稱。
下列屬性在 [必要條件] 對話方塊 (從 [發行] 頁面存取) 中設定。
BootstrapperEnabled 能夠判斷是否要產生 setup.exe 啟動載入器。
IsWebBootstrapper 能夠判斷 setup.exe 啟動載入器是透過 Web 還是以磁碟架構的模式運作。
InstallURL、SupportUrl、PublishURL 和 UpdateURL
下表顯示 ClickOnce 部署的四個 URL 選項。
URL 選項 |
說明 |
---|---|
PublishURL |
如果您要將 ClickOnce 應用程式發行至網站時需要。 |
InstallURL |
選擇項。 如果安裝網站不同於 PublishURL 時,請設定這個 URL 選項。 例如,您可以將 PublishURL 設為 FTP 路徑,並且將 InstallURL 設為 Web URL。 |
SupportURL |
選擇項。 如果支援網站不同於 PublishURL 時,請設定這個 URL 選項。 例如,您可以將 SupportURL 設定為您公司的客戶支援網站。 |
UpdateURL |
選擇項。 如果更新位置不同於 InstallURL 時,請設定這個 URL 選項。 例如,您可以將 PublishURL 設為 FTP 路徑,並且將 UpdateURL 設為 Web URL。 |