Как удалить с помощью msiexec, используя идентификатор продукта, без MSI-файла

Я пытаюсь автоматизировать удаление пакетов, созданных с помощью WiX, с целью изменения стека и конфигурации установленного программного обеспечения без повторной подготовки всей ОС. В конце концов я буду использовать сценарии powershell, чтобы сделать это, но в настоящее время я не могу заставить свой тестовый пакет интерактивно деинсталлироваться с помощью cmd.

Если я бегу:

msiexec /x '{A4BFF20C-A21E-4720-88E5-79D5A5AEB2E8}'

msiexec /x A4BFF20C-A21E-4720-88E5-79D5A5AEB2E8

Я получил:

"Не удалось открыть установочный пакет. Убедитесь, что пакет существует и к нему можно получить доступ, или обратитесь к поставщику приложения, чтобы убедиться, что это действительный пакет установщика Windows".

Если я бегу: msiexec /x {A4BFF20C-A21E-4720-88E5-79D5A5AEB2E8}

Я получил:

"Это действие действительно только для продуктов, которые установлены в настоящее время"

Я посмотрел руководство по установке Windows, документацию по WiX, документацию по msiexec и использовал orca для самостоятельного просмотра.msi, но на самом деле я не нашел ничего, что давало бы четкое представление о том, как обрабатывается удаление. Требуется ли MSI-файл, и если нет, то почему установщик Windows считает, что это происходит, когда ему присваивается GUID?

Код WiX для установщика.msi:

<?xml version='1.0' encoding='windows-1252'?>
<Wix xmlns='htp://schemas.microsoft.com/wix/2006/wi' >

  <!--DO NOT COPY / PASTE THE PRODUCT ID GUID BELOW TO YOUR OWN WIX SOURCE -->

  <Product Id='A4BFF20C-A21E-4720-88E5-79D5A5AEB2E8' Language='2057' 
           Manufacturer='COMPANYNAME IT-Operations' 
           Name='COMPANYNAMEServerListener' Version='1.0.0' 
           UpgradeCode='PUT-GUID-HERE'>

   <Package Id='*' Manufacturer='COMPANYNAME IT-Operations' Compressed='yes' />
   <Media Id='1' Cabinet='COMPANYNAMEServerListener.cab' EmbedCab='yes' />

    <Directory Id='TARGETDIR' Name='SourceDir'>
      <Directory Id='ProgramFilesFolder' Name='PFiles'>
      <Directory Id='COMPANYNAME' Name='COMPANYNAME'>
        <Directory Id='INSTALLDIR' Name='COMPANYNAMEServerListener'>
        <Component Id='MainExecutable' Guid='*' >
          <File Id='COMPANYNAMEServerListener.exe' 
                Source='COMPANYNAMEServerListener.exe' Vital='yes' 
                KeyPath='yes' />
          <ServiceInstall 
            Id='COMPANYNAMEServerListenerInstall'
            DisplayName='COMPANYNAMEServerListener'
            Description='Accepts and discards TCP connections on port 28028 to indicate that this server is alive and ready to be controlled'
            Name='COMPANYNAMEServerListener'
            Account='NT AUTHORITY\LocalService'
            ErrorControl='normal'
            Start='auto'
            Type='ownProcess'
            Vital='yes'           
          >
            <ServiceDependency Id='tcpip'/>
          </ServiceInstall>
          <ServiceControl Id="StartService" Start="install" Stop="both" Remove="uninstall" Name="COMPANYNAMEServerListener" Wait="yes" />
        </Component>
        </Directory>
        </Directory>
      </Directory>
      </Directory>

    <Feature Id='Complete' Level='1' >
      <ComponentRef Id='MainExecutable' />
    </Feature>

    <CustomTable Id ="COMPANYNAMEMetadata">
      <Column Id="Property" Type="string" Category="Identifier" PrimaryKey="yes"/>
      <Column Id="Value" Type="string"/>
      <Row>
      <Data Column="Property">InstallString</Data>
      <Data Column="Value">/qn</Data>
      </Row>
    </CustomTable>


  </Product>
</Wix>

7 ответов

Решение

Спасибо всем за помощь - оказывается, это проблема WiX.

Когда GUID идентификатора продукта был оставлен в явном виде и жестко закодирован, как в вопросе, полученный MSI-файл не имел свойства ProductCode, но имел свойство Product ID вместо этого при проверке с помощью orca.

Как только я изменил GUID на '*' для автоматической генерации, обнаружился ProductCode, и все отлично работает с синтаксисом, подтвержденным другими ответами.

Указанная вами команда верна: msiexec / x {A4BFF20C-A21E-4720-88E5-79D5A5AEB2E8}

Если вы получили " Это действие действительно только для продуктов, которые в настоящее время установлены ", вы использовали нераспознанный код продукта или пакета, и вы должны найти правильный. Часто это может быть вызвано использованием ошибочного кода пакета вместо кода продукта для удаления - код пакета изменяется при каждой перестройке файла MSI и является единственным указанием, которое вы видите при просмотре страницы свойств файла MSI. Он должен работать для удаления, если вы используете правильный. Нет места для ошибки. Если вы хотите найти код продукта, вам нужно открыть MSI. Код продукта находится в таблице свойств.


ОБНОВЛЕНИЕ, январь 2018 г.:

Учитывая все перенаправления реестра, я не уверен, что приведенный ниже подход на основе реестра более приемлем. Я не проверил должным образом, потому что теперь полагаюсь на следующий подход, использующий PowerShell: Как мне найти GUID продукта установленной установки MSI?

Также ознакомьтесь с этим справочным ответом, описывающим различные способы удаления пакета MSI и способы определения версии установленного продукта: удаление файла MSI из командной строки без использования msiexec


Legacy, опция реестра:

Вы также можете найти код продукта, просматривая реестр из этого базового ключа: HKEY_LOCAL_MACHINE \ SOFTWARE \ Microsoft \ Windows \ CurrentVersion \ Uninstall. Нажмите F3 и найдите название вашего продукта. (Если это 32-разрядный установщик на 64-разрядной машине, он может находиться в папке HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Windows\CurrentVersion\Uninstall).

Устаревший вариант PowerShell: (в значительной степени похож на новый, связанный ответ выше)

Наконец, вы можете найти код продукта с помощью PowerShell:

get-wmiobject Win32_Product | Format-Table IdentifyingNumber, Name

Похожие посты: WiX - значительное обновление при установке нескольких экземпляров (снимок экрана с информацией о том, как найти код продукта в MSI).

msiexec.exe /x "{588A9A11-1E20-4B91-8817-2D36ACBBBF9F}" /q

Хорошо, что этот анализ действительно легко и детерминистически анализировать: либо пакет msi действительно не установлен в системе, либо вы что-то делаете неправильно. Конечно, правильный вызов:

msiexec /x {A4BFF20C-A21E-4720-88E5-79D5A5AEB2E8}

(Конечно, необходимы права администратора - с помощью фигурных скобок без кавычек - кавычки нужны только в том случае, если в командной строке указаны пути или значения с пробелами.)
Если сообщение: "Это действие действительно только для продуктов, которые в настоящее время установлены", то это действительно так. Либо пакет с этим ProductCode не установлен, либо произошла опечатка.

Чтобы проверить, где находится ошибка:

  1. Сначала попробуйте щелкнуть правой кнопкой мыши (вероятно) установленный MSI-файл. Вы увидите (кроме "Установить" и "Восстановить") запись об удалении. Нажмите на это.
    a) Если эта деинсталляция работает, ваш msi имеет другой ProductCode, чем вы ожидаете (возможно, у вас неправильный источник WiX или ваша сборка имеет динамическую регистрацию, где ProductCode изменяется).
    б) Если при удалении выдается то же самое "... только для уже установленных продуктов", пакет не устанавливается (что является обязательным условием для его удаления).

  2. Если это был случай 1.a), вы можете найти правильный ProductCode вашего пакета, если откроете свой MSI-файл с помощью Orca, Insted или другого редактора / инструмента. Просто Google для них. Посмотрите там в таблице с именем "Свойство" и найдите строку "Код продукта" в первом столбце. Во втором столбце есть правильное значение.

Других возможностей нет.

Просто предложение для используемой командной строки: я бы добавил хотя бы "/qb" для простого индикатора выполнения или параметр "/qn" (последний для полной тихой деинсталляции, но имеет смысл только если вы уверены, что это работает).

У команды {} нет причин не работать. Полуочевидные вопросы:

  1. Вы уверены, что продукт действительно установлен! Что-то есть в ARP/ Программы и возможности.

  2. Оригинальная установка фактически видна в текущем контексте. Выглядит так, как будто это может быть установка для каждого пользователя, и если вы вошли в систему как кто-то другой, то он об этом не узнает - вам нужно будет войти под той же учетной записью, что и при первоначальной установке.

  3. Если каталог \ windows \ installer был поврежден, кэшированный файл будет отсутствовать, и это используется для удаления.

Попробуйте эту командуmsiexec /x {product-id} /qr

Вам нужно / д в конце

MsiExec.exe /x {2F808931-D235-4FC7-90CD-F8A890C97B2F} /q
Другие вопросы по тегам