Get-HotFix

获取在本地或远程计算机上安装的修补程序。

语法

Get-HotFix
   [[-Id] <String[]>]
   [-ComputerName <String[]>]
   [-Credential <PSCredential>]
   [<CommonParameters>]
Get-HotFix
   [-Description <String[]>]
   [-ComputerName <String[]>]
   [-Credential <PSCredential>]
   [<CommonParameters>]

说明

此 cmdlet 仅在 Windows 平台上可用。

Get-Hotfix cmdlet 使用 Win32_QuickFixEngineering WMI 类列出在本地计算机或指定远程计算机上安装的修补程序。

示例

示例 1:获取本地计算机上的所有修补程序

Get-Hotfix cmdlet 获取在本地计算机上安装的所有修补程序。

Get-HotFix

Source         Description      HotFixID      InstalledBy          InstalledOn
------         -----------      --------      -----------          -----------
Server01       Update           KB4495590     NT AUTHORITY\SYSTEM  5/16/2019 00:00:00
Server01       Security Update  KB4470788     NT AUTHORITY\SYSTEM  1/22/2019 00:00:00
Server01       Update           KB4480056     NT AUTHORITY\SYSTEM  1/24/2019 00:00:00

示例 2:从多台按字符串筛选的计算机中获取修补程序

Get-Hotfix 命令使用参数来获取远程计算机上安装的修补程序。 结果按指定的描述字符串进行筛选。

Get-HotFix -Description Security* -ComputerName Server01, Server02 -Credential Domain01\admin01

Get-Hotfix 使用 Description 参数和包含星号 (*) 通配符的字符串 Security 筛选输出。 ComputerName 参数包含以逗号分隔的远程计算机名称字符串。 Credential 参数指定有权访问远程计算机和运行命令的用户帐户。

示例 3:验证是否已安装更新并将计算机名称写入文件

此示例中的命令验证是否安装了特定更新。 如果未安装更新,则计算机名称将写入文本文件。

$A = Get-Content -Path ./Servers.txt
$A | ForEach-Object { if (!(Get-HotFix -Id KB957095 -ComputerName $_))
    { Add-Content $_ -Path ./Missing-KB957095.txt }}

$A 变量包含 Get-Content 从文本文件中获取的计算机名称。 $A 中的对象通过管道向下发送到 ForEach-Objectif 语句将 Get-Hotfix cmdlet 与 Id 参数一起使用,并为每个计算机名称指定一个特定的 ID 号。 如果计算机未安装指定的修补程序 ID,则 Add-Content cmdlet 会将计算机名称写入文件。

示例 4:获取本地计算机上的最新修补程序

此示例获取计算机上安装的最新修补程序。

(Get-HotFix | Sort-Object -Property InstalledOn)[-1]

Get-Hotfix 通过管道将对象向下发送到 Sort-Object cmdlet。 Sort-Object 按升序对对象进行排序,并使用 Property 参数计算每个 InstalledOn 日期。 数组表示法 [-1] 会选择最近安装的修补程序。

参数

-ComputerName

指定远程计算机。 键入远程计算机的 NetBIOS 名称、Internet 协议 (IP) 地址或完全限定的域名 (FQDN)。

如果未指定 ComputerName 参数,则 Get-Hotfix 会在本地计算机上运行。

ComputerName 参数不依赖于 Windows PowerShell 远程处理。 如果计算机未配置为运行远程命令,请使用 ComputerName 参数。

Type:String[]
Aliases:CN, __Server, IPAddress
Position:Named
Default value:None
Required:False
Accept pipeline input:True
Accept wildcard characters:False

-Credential

指定有权访问计算机和运行命令的用户帐户。 默认为当前用户

键入用户名,如 User01Domain01\User01;或输入 Get-Credential cmdlet 生成的 PSCredential 对象。 如果键入用户名,系统会提示输入密码。

凭据存储在 PSCredential 对象中,密码存储为 SecureString

注意

有关 SecureString 数据保护的详细信息,请参阅 SecureString 的安全性如何?

Type:PSCredential
Position:Named
Default value:Current user
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Description

Get-HotFix 使用 Description 参数来指定修补程序类型。 允许使用通配符。

Type:String[]
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:True

-Id

筛选特定修补程序 ID 的 Get-HotFix 结果。 不接受通配符。

Type:String[]
Aliases:HFID
Position:0
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

输入

String

可以通过管道将包含计算机名称的字符串传递给此 cmdlet。

输出

ManagementObject

此 cmdlet 返回表示计算机上的修补程序的对象。

备注

此 cmdlet 仅在 Windows 平台上可用。

Win32_QuickFixEngineeringWMI 类表示应用于当前操作系统的小型系统范围的更新,通常称为快速修补工程 (QFE) 更新。 此类仅返回由基于组件的服务 (CBS) 提供的更新。 注册表中未列出这些更新。 Win32_QuickFixEngineering 不会返回由 Microsoft Windows Installer (MSI) 或 Windows 更新站点提供的更新。 有关详细信息,请参阅 Win32_QuickFixEngineering 类

Get-HotFix 输出在不同操作系统上可能有所不同。