[英]How do I add C# methods to an existing large wix script
我们有一个现有的 wix 脚本,它非常复杂且很长。 所有 CustomActions 都使用内联 vbscript 执行。
我想将其中一些操作从 vbscript 切换到 C#。 所有示例都以“在 VisualStudio 中创建一个 wix 项目...”开头。 有没有关于如何将 C# 代码添加到现有 wix 项目的示例? 一个是使用老式 wix 命令行应用程序构建的?
先无耻宣传C++自定义动作! :-)。
和: “WiX 快速入门” (一些指向好的 WiX 和 MSI 资源的指针)。
一步一步:我会试一试,请试试这个(如果你完成了这些初步步骤,你可能想跳到底部的源代码 - 这是真正的一步一步,非常慢开始行动 - 您可能会直接从 WiX 源中获得所需内容):
在 WiX Visual Studio 解决方案中, right click solution node at top
=> Add
=> New Project...
展开 WiX Toolset 节点,选择 v3(前提是你使用的 WiX 版本)
双击"C# Custom Action Project for WiX v3"
右键单击 WiX 项目中的"References"
(不在 C# 项目中)=> Add Reference...
转到"Projects"
并添加对C# project
的引用(双击并确定)
进行测试构建。 前提是之前没有错误,现在应该没有错误。
您应该会在构建输出窗口中看到类似"CustomAction1.CA.dll"
的内容。 后缀*.CA.dll
被添加到原始托管代码 dll 的 win32 包装 dll 中。 所有这些都由 WiX 本身处理——或者实际上是 WiX 的 Votive Visual Studio 集成——只需知道区别:
"CustomAction1.dll"
- 托管代码 dll。"CustomAction1.CA.dll"
- 包含本机一个和其他几个组件的本机 win32 包装器 dll。 Include this version in your MSI
。添加以下代码段:
<Binary Id="CustomActions" SourceFile="$(var.CustomAction1.TargetDir)\\$(var.CustomAction1.TargetName).CA.dll" />
以上应该将实际的 C# dll 编译到 MSI 中。 您可以在 Orca 中打开 MSI 并在二进制表中查看。
这不是很好,但我喜欢添加对System.Windows.Forms
的引用,并使用MessageBox.Show
从自定义操作中显示一个对话框,以确保它按预期运行。 我还为在调试模式下构建的 dll 添加了应用程序调试器启动命令。 这样 Visual Studio 将被自动调用(如果一切正常),以便代码可以被单步执行。
参考添加到"System.Windows.Forms"
通过右键单击C#项目的参考节点,然后添加"System.Windows.Forms"
。 还要添加"using System.Windows.Forms;"
到源文件的顶部 - 请参阅下面的完整源代码。 关键是要记住在项目级别引用"System.Windows.Forms"
。
现在将此作为测试代码添加到自定义操作项目的"CustomAction1"
自定义操作代码片段(请参阅底部的代码部分以获取完整源代码):
// will launch the debugger for debug-build dlls #if DEBUG System.Diagnostics.Debugger.Launch(); #endif MessageBox.Show("hello world");
要获得标准设置 GUI(对于阅读此内容的其他人), WiXUIExtension
按照此处的说明添加对WiXUIExtension
的引用(这是创建可编译并具有 GUI 的基本 WiX 项目的分步步骤),然后将其注入你的消息来源:
<UIRef Id="WixUI_Mondo" />
我喜欢将<MediaTemplate />
更改为<MediaTemplate EmbedCab="yes" />
以避免外部源 cab 文件(通过此更改,cabs 被编译到 MSI 中)。
如果您没有添加任何组件,您可以添加它以在您的 MSI 中包含notepad.exe
以在INSTALLFOLDER
目录下进行测试安装(只是在没有源文件的情况下安装某些东西的技巧 - 应该在任何机器上解析的源路径) - 替换整个“TODO”部分 - 请参阅下面的完整来源:
<Component Feature="ProductFeature"> <File Source="$(env.SystemRoot)\\notepad.exe" /> </Component>
现在我们需要声明实际的自定义操作并将其插入到安装序列中。 让我们在之前的<Binary> element
下面添加这个:
<CustomAction Id="CA1" BinaryKey="CustomActions" DllEntry="CustomAction1"/> <InstallUISequence> <Custom Action="CA1" After="CostFinalize" /> </InstallUISequence> <InstallExecuteSequence> <Custom Action="CA1" After="CostFinalize" /> </InstallExecuteSequence>
现在构建并测试运行 MSI。 您应该会收到许多"hello world"
消息。
这是 C#/托管代码自定义操作的整体"heartbeat"
——我有时使用它们的方式。
WiX 源实际:现在,合成 -记得替换所有 GUID! :
构造:
$(env.SystemRoot)
- 在下面的 WiX 源代码中 - 获取环境变量%SystemRoot%
- 在大多数系统上解析为C:\\
(列出环境变量打开cmd.exe
并输入set
并按Enter
) . 因此,以下源代码应无需修改即可在所有系统上编译:
<?xml version="1.0" encoding="UTF-8"?>
<Wix xmlns="http://schemas.microsoft.com/wix/2006/wi">
<Product Id="*" Name="DemoCA" Language="1033" Version="1.0.0.0" Manufacturer="test" UpgradeCode="0adf972a-5562-4a6f-a552-dd1c16761c55">
<Package InstallerVersion="200" Compressed="yes" InstallScope="perMachine" />
<MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." />
<MediaTemplate EmbedCab="yes" />
<UIRef Id="WixUI_Mondo" />
<!-- START CUSTOM ACTION CONSTRUCTS -->
<Binary Id="CustomActions" SourceFile="$(var.CustomAction1.TargetDir)\$(var.CustomAction1.TargetName).CA.dll" />
<CustomAction Id="CA1" BinaryKey="CustomActions" DllEntry="CustomAction1"/>
<InstallUISequence>
<Custom Action="CA1" After="CostFinalize" />
</InstallUISequence>
<InstallExecuteSequence>
<Custom Action="CA1" After="CostFinalize" />
</InstallExecuteSequence>
<!-- END CUSTOM ACTION CONSTRUCTS -->
<Feature Id="ProductFeature" Title="AddingCSharpCustomActions" Level="1">
<ComponentGroupRef Id="ProductComponents" />
</Feature>
</Product>
<Fragment>
<Directory Id="TARGETDIR" Name="SourceDir">
<Directory Id="ProgramFilesFolder">
<Directory Id="INSTALLFOLDER" Name="AddingCSharpCustomActions"/>
</Directory>
</Directory>
</Fragment>
<Fragment>
<ComponentGroup Id="ProductComponents" Directory="INSTALLFOLDER">
<Component Feature="ProductFeature">
<File Source="$(env.SystemRoot)\notepad.exe" />
</Component>
</ComponentGroup>
</Fragment>
</Wix>
简要步骤:所需更改的简短摘要:
MediaTemplate
设置为使用嵌入式MediaTemplate
(可选,对于示例工作不是必需的)。自定义操作代码:最后是实际的 C# 自定义操作测试代码 - 使用 Debugger.Launch 更新,它将启动调试构建 DLL 的调试器。 然后,您可以将调试器附加到正确的源项目并逐步执行代码:
using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.Deployment.WindowsInstaller;
using System.Windows.Forms;
namespace CustomAction1
{
public class CustomActions
{
[CustomAction]
public static ActionResult CustomAction1(Session session)
{
#if DEBUG
System.Diagnostics.Debugger.Launch();
#endif
MessageBox.Show("hello world");
session.Log("Begin CustomAction1");
return ActionResult.Success;
}
}
}
链接:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.