Installation “处理”;已安装此产品的另一个版本。无法继续安装此版本…”;

Installation “处理”;已安装此产品的另一个版本。无法继续安装此版本…”;,installation,windows-installer,installshield,installshield-2011,Installation,Windows Installer,Installshield,Installshield 2011,我的安装程序有32位和64位版本,它们(几乎)有完全相同的代码和自定义操作序列(只有与此问题无关的细微差异) 我希望我的安装程序检测以前是否已安装,在这种情况下,运行我自己的代码,而不是显示默认的Windows installer错误: 已安装此产品的另一个版本。安装 此版本无法继续。要配置或删除现有的 在本产品的版本中,请使用“控制面板”上的“添加/删除程序” 我的32位安装程序工作得非常好,因为如果我在产品已经安装时运行安装程序,它会运行我的自定义代码,但是我的64位安装程序中的相同代码和自

我的安装程序有32位和64位版本,它们(几乎)有完全相同的代码和自定义操作序列(只有与此问题无关的细微差异)

我希望我的安装程序检测以前是否已安装,在这种情况下,运行我自己的代码,而不是显示默认的Windows installer错误:

已安装此产品的另一个版本。安装 此版本无法继续。要配置或删除现有的 在本产品的版本中,请使用“控制面板”上的“添加/删除程序”

我的32位安装程序工作得非常好,因为如果我在产品已经安装时运行安装程序,它会运行我的自定义代码,但是我的64位安装程序中的相同代码和自定义操作不能正常工作,并且总是显示不需要的错误消息

CheckPreviousVersion是在UI序列中作为自定义操作调用的第一个函数,我尝试将它放在不同的位置,如InstallValidate之后,但没有任何效果

我已经检查了详细日志文件,但找不到任何可能解释此行为的内容,以下是日志的一部分:

=== Verbose logging started: 05/03/2013  16:27:20  Build type: SHIP UNICODE 5.00.7601.00  Calling process: C:\Windows\system32\msiexec.exe
===

MSI (c) (0C:94) [16:27:20:331]: Machine policy value 'Debug' is 0 MSI (c) (0C:94) [16:27:20:331]: ******* RunEngine:
           ******* Product: foo.msi
           ******* Action: 
           ******* CommandLine: ********** MSI (c) (0C:94) [16:27:21:546]: Machine policy value 'DisableUserInstalls' is 0 MSI (c) (0C:94) [16:27:21:557]: SOFTWARE RESTRICTION POLICY: Verifying package --> 'C:\Builds\.msi' against software restriction policy MSI (c) (0C:94) [16:27:21:557]: Note: 1: 2262 2: DigitalSignature 3:
-2147287038  MSI (c) (0C:94) [16:27:21:557]: SOFTWARE RESTRICTION POLICY: C:\Builds\.msi is not digitally signed MSI (c) (0C:94) [16:27:21:558]: SOFTWARE RESTRICTION POLICY: C:\Builds.msi is permitted to run at the 'unrestricted' authorization level. MSI (c) (0C:94) [16:27:21:584]: Cloaking enabled. MSI (c) (0C:94) [16:27:21:584]: Attempting to enable all disabled privileges before calling Install on Server MSI (c) (0C:94) [16:27:21:586]: End dialog not enabled MSI (c) (0C:94) [16:27:21:586]: Original package ==> C:\Builds\....msi MSI (c) (0C:94) [16:27:21:586]: Package we're running from ==> C:\Builds\.....msi MSI (c) (0C:94) [16:27:21:589]: APPCOMPAT: Uninstall Flags override found. MSI (c) (0C:94) [16:27:21:589]: APPCOMPAT: Uninstall VersionNT override found. MSI (c) (0C:94) [16:27:21:589]: APPCOMPAT: Uninstall ServicePackLevel override found. MSI (c) (0C:94) [16:27:21:589]: APPCOMPAT: looking for appcompat database entry with ProductCode '{B8CBA92E-2140-48AB-B4EA-A4C3FF10295B}'. MSI (c) (0C:94) [16:27:21:589]: APPCOMPAT: no matching ProductCode found in database. MSI (c) (0C:94) [16:27:21:599]: MSCOREE not loaded loading copy from system32 MSI (c) (0C:94) [16:27:21:608]: Machine policy value 'DisablePatch' is 0 MSI (c) (0C:94) [16:27:21:608]: Machine policy value 'AllowLockdownPatch' is 0 MSI (c) (0C:94) [16:27:21:608]: Machine policy value 'DisableLUAPatching' is 0 MSI (c) (0C:94) [16:27:21:608]: Machine policy value 'DisableFlyWeightPatching' is 0 MSI (c) (0C:94) [16:27:21:609]: APPCOMPAT: looking for appcompat database entry with ProductCode '{}'. MSI (c) (0C:94) [16:27:21:609]: APPCOMPAT: no matching ProductCode found in database. MSI (c) (0C:94) [16:27:21:609]: Transforms are not secure. MSI (c) (0C:94) [16:27:21:609]: PROPERTY CHANGE: Adding MsiLogFileLocation property. Its value is 'C:\Builds\Angoss\Products\Workstation\single-exec\INSTALL64.LOG'. MSI (c) (0C:94) [16:27:21:609]: Command Line: CURRENTDIRECTORY=C:\Builds\Angoss\Products\Workstation\single-exec CLIENTUILEVEL=0 CLIENTPROCESSID=7948  MSI (c) (0C:94) [16:27:21:609]: PROPERTY CHANGE: Adding PackageCode property. Its value is '{}'. MSI (c) (0C:94) [16:27:21:609]: Product Code passed to Engine.Initialize:  '' MSI (c) (0C:94) [16:27:21:609]: Product Code from property table before transforms: '{}' MSI (c) (0C:94) [16:27:21:609]: Product Code from property table after transforms:  '{}' MSI (c) (0C:94) [16:27:21:609]: Product registered: entering maintenance mode MSI (c) (0C:94) [16:27:21:609]: Determined that existing product (either this product or the product being upgraded with a patch) is installed per-machine. MSI (c) (0C:94) [16:27:21:609]: PROPERTY CHANGE: Adding ProductState property. Its value is '5'. MSI (c) (0C:94) [16:27:21:609]: PROPERTY CHANGE: Adding ProductToBeRegistered property. Its value is '1'. MSI (c) (0C:94) [16:27:21:609]: Entering CMsiConfigurationManager::SetLastUsedSource. MSI (c) (0C:94) [16:27:21:609]: Specifed source is already in a list. MSI (c) (0C:94) [16:27:21:609]: User policy value 'SearchOrder' is 'nmu' MSI (c) (0C:94) [16:27:21:609]: Machine policy value 'DisableBrowse' is 0 MSI (c) (0C:94) [16:27:21:609]: Machine policy value 'AllowLockdownBrowse' is 0 MSI (c) (0C:94) [16:27:21:609]: Adding new sources is allowed. MSI (c) (0C:94) [16:27:21:609]: PROPERTY CHANGE: Adding PackagecodeChanging property. Its value is '1'. Another version of this product is already installed. Installation of this version cannot continue. To configure or remove the existing version of this product, use Add/Remove Programs on the Control Panel.

此消息通常仅在开发阶段出现,而不是在最终用户计算机上出现。出现此消息的原因是,您只修改了软件包中的资源并重新生成它,而不增加版本号,因此Windows Installer会看到计算机上有一个具有相同产品代码和名称,但具有不同软件包代码的软件包

您的用户永远不会收到此消息,因为我假设您在发布包时会增加版本号。这也是基于函数的名称,即“CheckPreviousVersion”


如果您希望在机器上发现旧版本时显示自定义消息,请确保您首先安装了旧版本,当前安装了最新版本,但使用的是另一个先前构建的软件包(即不同的软件包代码)。

如果您使用的是BasicMSI安装程序,您可以创建检查以下注册表项的系统搜索:

HKEY\U LOCAL\U MACHINE\SOFTWARE\(Wow6432Node)\Microsoft\Windows\CurrentVersion\Uninstall\YOURPRODUCTCODE

如果此密钥可用,则会在计算机上安装旧版本的安装程序。现在创建一个放置在“CheckPreviousVersion”之前的自定义操作来运行代码。将此自定义操作的条件设置为系统搜索中的属性


这应该可以解决问题。

我是最终用户,现在就明白了。联系软件供应商,他们可能会给你(或在他们的网站上发布)相同版本的两个不同版本。唯一的解决方案是手动卸载旧版本(从控制面板),然后安装新版本。如果我更改了版本号,但没有更改产品代码,为什么会出现这种情况?