如何检测Windows机箱上是否安装了特定证书?

前端之家收集整理的这篇文章主要介绍了如何检测Windows机箱上是否安装了特定证书?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
特定应用程序部署的前提条件是,在安装之前,我们需要在PC的 Windows Trusted Publishers证书库中安装特定的PKI证书.

有没有办法检测是否已经安装了特定的证书?理想情况下使用单线程命令或短脚本(可用于预先请求检测,或作为SCCM 2012中的依赖性检查)?

似乎有很多命令和脚本用于列出所有已安装的证书,或者所有已安装的证书即将到期,但我无法确定是否已安装某个特定证书.

使用PowerShell单线程可以实现这一点,您只需要一种简单的方法来识别该证书(我使用的是证书的ThumbPrint).

如果您已经拥有一台已知安装了证书的已知机器(通过使用certmgr.msc进行交互式检查的最简单方法),那么您可以使用该机器查找证书的指纹.

以下PowerShell命令将列出本地计算机上下文中Trusted Publisher存储中安装的所有证书:

Get-ChildItem -Path Cert:\LocalMachine\TrustedPublisher

显然,可以修改上面的路径,列出其他证书库,或者您可以使用以下命令查看(长列表)所有本地安装的证书:

Get-ChildItem -Path Cert: -Recurse

第一个命令应该给你一个像这样的输出

PS C:\> Get-ChildItem -Path Cert:\LocalMachine\TrustedPublisher


    Directory:
    Microsoft.PowerShell.Security\Certificate::LocalMachine\TrustedPublisher


Thumbprint                                Subject
----------                                -------
83EDC96EC3D55125EFFC77BC815F9133E268D5EB  CN="User,Test",OU=Testing Resources...
4DFF713712084D43DE6879C689F9A143C4A793BF  CN=Server One Self-signed

一旦找到了您正在寻找的证书的指纹,您就可以使用它来过滤结果,如下所示:

Get-ChildItem -Path Cert:\LocalMachine\TrustedPublisher | Where-Object {$_.Thumbprint -eq "83EDC96EC3D55125EFFC77BC815F9133E268D5EB"}

如果安装了证书,那应该返回证书的详细信息,如果没有,则返回任何内容.在其他用途​​中,此Powershell单线程可用作SCCM 2012应用程序中的自定义脚本检测方法.

(使用的资源:Use PowerShell to Find Certificates that are About to Expire | PowerTip: Use PowerShell to Discover Certificate Thumbprints | Using the Where-Object Cmdlet)

猜你在找的Windows相关文章