2010-09-16 80 views
10

我有一个为x86(32位)和x64(64位)平台构建的C#应用​​程序。我的构建系统目前输出两个MSI安装程序,每个平台一个。如果它有所不同,我的C#应用​​程序包含一个Windows任务栏工具栏,这意味着安装的DLL必须由explorer.exe进程加载。单个MSI安装正确的32位或64位C#应用程序

是否可以生成一个MSI安装程序,根据当前操作系统是否是64位操作系统,安装我的应用程序的正确版本?

目前已经通过使用http://dotnetinstaller.codeplex.com/来生成一个执行体系结构检查然后启动正确的MSI的EXE来实现。但是,我更喜欢纯粹基于MSI的方法。

+0

相关:[我如何有条件地安装基于目标机器(32位或64位)的WiX文件?](http://stackoverflow.com/questions/730534/) – 2012-10-05 20:04:05

回答

7

不,这是不可能的。查看Heath Stewart的Different Packages are Required for Different Processor Architectures的帖子。与MSI一起处理这个问题的唯一方法是根据您所描述的方式进行引导。如果您只需要在64位位置放置文件或密钥,可以(但不推荐)在自定义操作中执行此操作,但更改目标安装位置并使用内置MSI文件支持会赢得'工作。

+0

+1高度相关的链接。 – Brian 2010-09-16 14:28:59

6

你可以解决这个问题。在第三个部署项目下打包2个安装程序。创建一个自定义操作来检查正在运行的操作系统版本,然后使安装程序调用正确的安装程序。

事情是这样的:

[RunInstaller(true)] 
public partial class MyInstaller: Installer 
{ 
    String installerPath; 

    public MyInstaller() 
    { 
     InitializeComponent();  
     if (Is64Bit())//running as 64-bit 
     { 
      installerPath= @"installfolder\my64bitsetup.exe"; 
     } 
     else 
     { 
      installerPath= @"installfolder\my32bitsetup.exe"; 
     } 
    } 

    [SecurityPermission(SecurityAction.Demand)] 
    public override void Install(IDictionary stateSaver) 
    { 
     base.Install(stateSaver); 
    } 

    [SecurityPermission(SecurityAction.Demand)] 
    public override void Commit(IDictionary savedState) 
    { 
     base.Commit(savedState); 
     MyInstall(); 
    } 

    [SecurityPermission(SecurityAction.Demand)] 
    public override void Rollback(IDictionary savedState) 
    { 
     base.Rollback(savedState); 
    } 

    [SecurityPermission(SecurityAction.Demand)] 
    public override void Uninstall(IDictionary savedState) 
    { 
     base.Uninstall(savedState); 
     base.Commit(savedState); 
    } 

    private void MyInstall() 
    { 
     ProcessStartInfo procStartInfo = new ProcessStartInfo("cmd.exe", "/c " + installerPath); 
     RunProcess(procStartInfo); 
    } 

    private void RunProcess(ProcessStartInfo procStartInfo) 
    { 
     Process proc = new Process(); 
     proc.StartInfo = procStartInfo; 
     proc.Start(); 
     proc.WaitForExit(); 
    } 

[DllImport("kernel32.dll", SetLastError = true, CallingConvention = CallingConvention.Winapi)] 
[return: MarshalAs(UnmanagedType.Bool)] 
public static extern bool IsWow64Process([In] IntPtr hProcess, [Out] out bool lpSystemInfo); 

private bool Is64Bit() 
{ 
    return (IntPtr.Size == 8 || (IntPtr.Size == 4 && Is32BitProcessOn64BitProcessor())); 
} 

private bool Is32BitProcessOn64BitProcessor() 
{ 
    bool retVal; 
    IsWow64Process(Process.GetCurrentProcess().Handle, out retVal); 
    return retVal; 
} 

好吧,那是很久......

总之,在提交你可以肯定的是,安装已经解包,只要确保你有正确的路径。 (您可以将cmd命令从/ c更改为/ k以进行测试,这将保持命令提示符窗口处于活动状态,以便您看到消息)

您可以阅读更多关于自定义操作的信息,可以传递安装路径通过论据。

相关问题