ASP.NET製作安裝包數據打包

 

前幾天被老闆安排製作程序的安裝包,重來沒有做過,就想應該用什麼工具製作安裝包。現在有很多安裝程序製作的工具(wise等),下載了一個試試,覺得研究起來太麻煩,就想使用.Net的安裝程序製作的安裝包。不過在製作過程中還真是遇到了不少問題。

本文參考:李洪根 的“NET平臺下WEB應用程序的部署(安裝數據庫和自動配置)”
個人用的是C#,把他的VB代碼翻譯了一下,呵呵。

首先需要把你要建立的數據庫表結構導出來,使用slqserver的導出嚮導導出表結構,先保存到db.sql文件中吧。

可選步驟:安裝Framework引導程序插件。
安裝了這個插件你製作的安裝包就通過 Microsoft Visual Studio .NET 2003 引導程序插件,您可以輕而易舉地創建安裝程序,將 .NET Framework 1.1隨您的應用程序一起重新分發。
引導程序插件 PluginInstaller.msi 的下在地址: 
http://www.microsoft.com/downloads/details.aspx?FamilyID=627921a0-d9e7-43d6-a293-72f9c370bd19&displaylang=zh-cn

第一步:創建部署項目
1. 在“文件”菜單上指向“添加項目”,然後選擇“新建項目”。
2. 在“添加新項目”對話框中,選擇“項目類型”窗格中的“安裝和部署項目”,然後選擇“模板”窗格中的“安裝項目”。在“名稱”框中鍵入 Setup。
3. 單擊“確定”關閉對話框。
4. 項目被添加到解決方案資源管理器中,並且文件系統編輯器打開。

第二步:創建安裝程序類
1. 在“文件”菜單上指向“新建”,然後選擇“項目”。
2. 在“新建項目”對話框中,選擇“項目類型”窗格中的“項目”,然後選擇“模板”窗格中的“類庫”。在“名稱”框中鍵入 DBCustomAction。
3. 單擊“打開”關閉對話框。
4. 從“項目”菜單中選擇“添加新項”。
5. 在“添加新項”對話框中選擇“安裝程序類”。在“名稱”框中鍵入 DBCustomAction。
6. 單擊“確定”關閉對話框。(代碼附後)

第三步:將項目的輸出添加到部署項目中
1. 在“文件系統編輯器”中,選擇“應用程序”文件夾。在“操作”菜單上,指向“添加”,然後選擇“項目輸出”。
2. 在“添加項目輸出組”對話框中,選擇“項目”下拉列表中你的項目。
3. 單擊“確定”關閉對話框。
4. 從列表中選擇“主輸出”,然後單擊“確定”。

第四步:創建自定義安裝對話框
1. 在解決方案資源管理器中選擇“Setup”項目。在“視圖”菜單上指向“編輯器”,然後選擇“用戶界面”。
2. 在用戶界面編輯器中,選擇“安裝”下的“啓動”節點。在“操作”菜單上,選擇“添加對話框”。
3. 在“添加對話框”對話框中,選擇“許可協議”對話框,然後單擊“確定”關閉對話框。
4. 在“添加對話框”對話框中,選擇“文本框 (A)”對話框,然後單擊“確定”關閉對話框。
5. 在“操作”菜單上,選擇“上移”。重複此步驟,直到“文本框 (A)”對話框位於“安裝文件夾”節點之上。
6. 在“屬性”窗口中,選擇 BannerText 屬性並鍵入:安裝數據庫.。
7. 選擇 BodyText 屬性並鍵入:安裝程序將在目標機器上安裝數據庫。
8. 選擇 Edit1Label 屬性並鍵入:數據庫名稱:。
9. 選擇 Edit1Property 屬性並鍵入 CUSTOMTEXTA1。
10. 選擇 Edit1Value 屬性並鍵入:GsCrm。
11. 選擇 Edit2Label 屬性並鍵入:服務器名:。
12. 選擇 Edit2Property 屬性並鍵入 CUSTOMTEXTA2。
13. 選擇 Edit2Value 屬性並鍵入:(local)。
14. 選擇 Edit3Label 屬性並鍵入:用戶名:。
15. 選擇 Edit3Value 屬性並鍵入:sa。
16. 選擇 Edit3Property 屬性並鍵入 CUSTOMTEXTA3。
17. 選擇 Edit4Label 屬性並鍵入:sa用戶密碼:。
18. 選擇 Edit4Property 屬性並鍵入 CUSTOMTEXTA4。

第五步:創建自定義操作
1. 在解決方案資源管理器中選擇“Setup”項目。在“視圖”菜單上指向“編輯器”,然後選擇“自定義操作”。
2. 在自定義操作編輯器中選擇“安裝”節點。在“操作”菜單上,選擇“添加自定義操作”。
3. 在“選擇項目中的項”對話框中,雙擊“應用程序文件夾”。
4. 選擇“主輸出來自 DBCustomAction(活動)”項,然後單擊“確定”關閉對話框。
5. 在“屬性”窗口中,選擇 CustomActionData 屬性並鍵入 /dbname=[CUSTOMTEXTA1] /server=[CUSTOMTEXTA2] /user=[CUSTOMTEXTA3] /pwd=[CUSTOMTEXTA4] /targetdir="[TARGETDIR]/"。
附/targetdir="[targetdir]/"是安裝後的目標路徑,爲了在dbcustomaction類中獲得安裝後的路徑,我們設置此參數。
另外,安裝後的路徑也可以通過Reflection得到:
Dim Asm As System.Reflection.Assembly = _
System.Reflection.Assembly.GetExecutingAssembly
MsgBox("Asm.Location")

第六步:添加db.sql以及你需要的其他文件到項目中,然後就可以打包了。

還有最重要的一個問題,當時困擾了我三個多小時,就是用.net這個程序打包的程序,安裝過程用戶所選擇的安裝路徑中是不能含有空格的。爲什麼呢?原來是sql server的osql的執行命令行方式的時候,如果你的安裝路徑中含有空格的話,那個命令行是不能正確的執行的。“osql -U userId -P password -d dbname -i c:/test/db.sql”

另外安裝的時候也可以直接修改安裝後的app.config來完成你的配置,李洪根的文章中有相關介紹。

DBCustomAction.cs

using System;
using System.Data.SqlClient;
using System.Collections;
using System.ComponentModel;
using System.Configuration.Install;

namespace DBCustomAction
{
 /// <summary>
 /// DBCustomAction 的摘要說明。
 /// </summary>
 [RunInstaller(true)]
 public class DBCustomAction : System.Configuration.Install.Installer
 {
  /// <summary>
  /// 必需的設計器變量。
  /// </summary>
  private System.ComponentModel.Container components = null;

  public DBCustomAction()
  {
   // 該調用是設計器所必需的。
   InitializeComponent();

   // TODO: 在 InitializeComponent 調用後添加任何初始化
  }

  /// <summary>
  /// 清理所有正在使用的資源。
  /// </summary>
  protected override void Dispose( bool disposing )
  {
   if( disposing )
   {
    if(components != null)
    {
     components.Dispose();
    }
   }
   base.Dispose( disposing );
  }


  #region 組件設計器生成的代碼
  /// <summary>
  /// 設計器支持所需的方法 - 不要使用代碼編輯器修改
  /// 此方法的內容。
  /// </summary>
  private void InitializeComponent()
  {
   components = new System.ComponentModel.Container();
  }
  #endregion

  private void ExecuteSql(string connStr,string DatabaseName, string Sql)
  {
   SqlConnection conn = new SqlConnection(connStr);
   SqlCommand cmd = new SqlCommand(Sql, conn);
   
   conn.Open();
   conn.ChangeDatabase(DatabaseName);
   try
   {
    cmd.ExecuteNonQuery();
   }
   finally
   {
    conn.Close();
   }
  }

  public override void Install(System.Collections.IDictionary stateSaver)
  {
   base.Install(stateSaver);
   try
   {
    //------------------------建立數據庫----------------------------
    string connStr = string.Format("data source={0};user id={1};password={2};persist security info=false;packet size=4096", this.Context.Parameters["server"], this.Context.Parameters["user"], this.Context.Parameters["pwd"]);
    ExecuteSql(connStr, "master", "CREATE DATABASE " + this.Context.Parameters["dbname"]);

    System.Diagnostics.Process sqlProcess = new System.Diagnostics.Process();
    sqlProcess.StartInfo.FileName = "osql.exe";
    sqlProcess.StartInfo.Arguments = string.Format(" -U {0} -P {1} -d {2} -i {3}db.sql", this.Context.Parameters["user"], this.Context.Parameters["pwd"], this.Context.Parameters["dbname"], this.Context.Parameters["targetdir"]);
    sqlProcess.StartInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;
    sqlProcess.Start();
    sqlProcess.WaitForExit(); //等待執行
   }
   catch(Exception e)
   {
    Console.Write(e.ToString());
   }
   finally
   {
   }
  }
 }
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章