我强烈建议查看 Wix#。请参阅http://www.codeproject.com/Articles/31407/Wix-WixSharp-managed-interface-for-WiX。
另请参阅 CodePlex 主页:http ://wixsharp.codeplex.com/
对于主要使用 C#、Wix# 编码的开发人员来说,这可能是最简单、最舒适的技能组合,而且它是免费的,并且直接集成到 Visual Studio 环境中。我在 Visual Studio 2012 和 2013 中使用它取得了巨大的成功。
对于需要创建 Windows Installer MSI 来部署他们的应用程序的 C# 开发人员,Wix# 可能是 Microsoft 从 VS2012 开始从 Visual Studio 中删除的“打包和部署”项目类型的最佳替代品。Wix 是 WiX (Windows Installer Xml) 工具集的 C# 前端。使用 Wix# 允许以 C# 语言构建完整的 Windows Installer MSI。
Wix# 对于广泛的安装/部署场景很有用,并且非常适合持续集成场景。有用于部署 Windows 桌面应用程序、安装 Windows 服务和安装 ASP.NET 网站以及更多类型的安装的 Wix# 示例。
Wix# 处理典型的安装程序要求,简单项目的 Wix# 安装程序代码确实很简单。对于更复杂且需要高级功能的应用程序安装,Wix# 可以在需要时利用完整 WiX 工具集的强大功能。例如,在安装 .NET 应用程序时,典型的要求是安装应用程序 exe 和 dll 文件,并在目标系统上定制一些 .NET 配置文件和/或注册表项。
下面是一个简单的 Wix# 安装程序的 C# 代码示例,该安装程序在目标系统上安装应用程序并修改一些配置文件。此示例假定您已经编写了一个名为“TailorMyConfig.exe”的实用程序,例如,一个使用 ConfigurationManager.AppSettings 例程的简单 C# 程序,并且您正在将该 exe 与您的应用程序一起部署。
using System;
using System.Windows.Forms;
using System.Diagnostics;
using Microsoft.Deployment.WindowsInstaller;
using WixSharp;
class Script
{
static public void Main(string[] args)
{
var project = new Project("MyProduct",
new Dir(@"%ProgramFiles%\My Company\My Product",
new File(@"Files\Bin\MyApp.exe"),
new File(@"Files\Bin\TailorMyConfig.exe")),
new ManagedAction("UpdateConfigFile"));
project.Id = new Guid("6f330b47-2577-43ad-9095-1861ba25889b");
Compiler.BuildMsi(project);
}
}
public class MyCustomAction
{
[CustomAction]
public static ActionResult UpdateConfigFile(Session session)
{
if (DialogResult.Yes == MessageBox.Show("Config file update ready to run.\n Update config file(s) now?",
"Config Tailoring Utility",
MessageBoxButtons.YesNo))
{
Process.Start("TailorMyConfig.exe", "Run utility to tailor config file to current system");
}
return ActionResult.Success;
}
}
请注意,有一些“更好”的方法可以使用 WiX XML 功能修改配置文件。为简单起见,上面的示例假定使用自定义编写的 C# exe 实用程序来修改配置文件。我建议改用 WiX XML 功能来执行此操作。您可以使用“XML 注入”的 Wix# 技术将几乎所有 WiX XML 功能直接合并到您的 Wix# 设置中。
请记住,Wix# 只是一个发出 WiX XML 语法的 C# 前端。在 Wix# 发出 WiX XML(wxs 文件)之后,可以轻松地对该 wxs 文件进行后处理以插入其他 WiX XML 功能。然后生成的 wxs 文件由 WiX 工具集编译成 MSI。
有关使用 XML 注入将 WiX XML 功能合并到 Wix# (C#) 安装中的示例,请查看此处在 Wix# 中,当仅部署注册表项时,如何避免在目标系统上创建物理文件夹?
在那个问题中,请参阅我的答案,该答案使用将委托连接到“WixSourceGenerated”事件的技术。
然后,您可以使用这种 XML 注入方法将一些 WiX XML 插入到您的安装程序中,从而完成配置文件的编辑。修改配置文件的一些典型 WiX XML 示例如下:
如何在安装期间修改 .NET 配置文件?
安装程序的另一个典型要求是在目标系统上添加或修改 Windows 注册表项。Wix# 使用“RegValue”类提供直接支持。使用 Wix# 的好处是,您还可以免费获得完整的“卸载”功能,包括将注册表项卸载/恢复到预安装状态。这是基于 WiX 工具集和 Windows Installer 技术构建的 Wix# 的自然结果。仅注册表 Wix# 安装程序的示例如下:在 Wix# 中,仅部署注册表项时,如何避免在目标系统上创建物理文件夹?
Wix# 方法在我的环境中非常有用,它允许使用熟悉的 C# 技能集,而无需一头扎进 WiX XML 安装程序技术的全部复杂性。
第一个接受的答案提倡这种方法:
一个好的策略是将 InstallShield LE 用作一个简单的容器,然后在 WiX 中进行大部分创作。我在我的博客中描述了这种模式:http:
//blog.iswix.com/2011/01/augmenting-installshield-using-windows_19.html
虽然这是一种很好且可行的方法,但我在这里建议的方法具有以下优点:
使用 Wix# PLUS WiX 方法的优势
- 无需处理 InstallShield LE 或任何其他专有安装程序产品
- 大多数安装程序都是用 C# 代码编写的,这是一种熟悉的技能
- 无需预先学习完整的 WiX 工具集环境;您可以从 C# 代码开始,然后根据需要使用 XML 注入添加高级 WiX 功能。
- 该方法在持续集成环境中运行良好,所有组件都适合安装在构建服务器上的 XCopy-deploy,并且所有组件都非常适合通过脚本实现自动化,例如 Powershell 脚本。
- 如果 Microsoft 再次更改与 Visual Studio 捆绑的安装程序工具的路线,您将不会受到影响。
IS LE + WIX 的共同点
- 建立在 WiX 工具集功能之上,因此 WiX XML 的所有功能都可以合并到安装程序中
- 在 SO 和其他地方提供了许多针对部署问题的 WiX 解决方案的优秀“操作指南”
- 生成真正的 MSI Windows 安装程序,具有卸载功能和该技术的所有强大功能。
- 在创建安装程序时,您需要了解有关 WiX 和 Windows Installer 技术的更多信息。高级功能通常需要放入 WiX XML。
- 两者都或多或少地无缝集成到 Visual Studio 环境中。(如果有的话,Wix# 方法会有一点优势)
因此,虽然另一种方法是可行的解决方案,但我建议将 Wix# + WiX 工具集作为 VS2012、VS2013、VS201x 的最小恶化路径。或许最大的优势在于,无论微软的营销经理为包含或从中提取部署技术做了什么幕后交易,您都不必再次更改底层部署技术和方法,从而再次被 Microsoft 蒙蔽双眼。视觉工作室。