Как извлечь продуктивный код из пакета MSI?
-
14-11-2019 - |
Вопрос
Как извлечь продуктCode из пакета MSI?Я хочу использовать его позже, чтобы удалить MSI через Msiexec, как описано здесь
Решение
Я могу подумать о десятках способов сделать это.Какие языки программирования вы используете в настоящее время и / или комфортно?
Посмотрите на
Вы можете использовать WIRUNSQL.VBS (приведен в платформе SDK) для запуска команды:
cscript /nologo WiRunSQL.vbs FOO.msi "SELECT Value FROM Property WHERE Property = 'ProductCode'"
. Другие советы
Вы можете достичь аналогичного эффекта, выполнив следующее в PowerShell на основе установленных программ:
Get-WmiObject -Class Win32_Product -Filter "Vendor LIKE 'The Company%' AND Name LIKE '%The Product%'" | %{
Write-Host "Uninstalling $($_.IdentifyingNumber)"
$_.Uninstall()
}
.
(обмел более жесткий запрос, тем быстрее его запустится - то подобное выше очень дорого)
Или вы можете подать заявку Общая техника здесь В вашем стеке.
Я написал функцию PowerShell, которую я использую при генерировании шоколадных пакетов на основе MSI, для обнаружения, если наш внутренний пакет устанавливает программу, которая была уже установлена через другие средства:
function Get-MsiProductCode {
[CmdletBinding()]
param (
[Parameter(Mandatory=$true)]
[ValidateScript({$_ | Test-Path -PathType Leaf})]
[string]$Path
)
function Get-Property ( $Object, $PropertyName, [object[]]$ArgumentList ) {
return $Object.GetType().InvokeMember($PropertyName, 'Public, Instance, GetProperty', $null, $Object, $ArgumentList)
}
function Invoke-Method ( $Object, $MethodName, $ArgumentList ) {
return $Object.GetType().InvokeMember( $MethodName, 'Public, Instance, InvokeMethod', $null, $Object, $ArgumentList )
}
$ErrorActionPreference = 'Stop'
Set-StrictMode -Version Latest
#http://msdn.microsoft.com/en-us/library/aa369432(v=vs.85).aspx
$msiOpenDatabaseModeReadOnly = 0
$Installer = New-Object -ComObject WindowsInstaller.Installer
$Database = Invoke-Method $Installer OpenDatabase $Path, $msiOpenDatabaseModeReadOnly
$View = Invoke-Method $Database OpenView "SELECT Value FROM Property WHERE Property='ProductCode'"
[void]( Invoke-Method $View Execute )
$Record = Invoke-Method $View Fetch
if ( $Record ) {
Get-Property $Record StringData 1
}
[void]( Invoke-Method $View Close @() )
Remove-Variable -Name Record, View, Database, Installer
}
.