3

我正在尝试签署一个Visual Studio 2012 extension打包为文件的VSIX文件。

我已按照http://www.jeff.wilcox.name/2010/03/vsixcodesigning/的说明进行操作;但是,我有兴趣在不指定 pfx 文件和密码的情况下执行签名。

例如,如果我要调用“signtool.exe”,我的命令行将是:

"signtool.exe" sign /n MySubjectName /t 'http://timestamp.verisign.com/scripts/timstamp.dll' /d "MyDescription" MyPackage.vsix

我了解此命令不适用于VSIX文件,但它确实适用于MSI存档。

使用此命令,我在调用signtool 时无需指定密码或pfx 文件。使用指定的主题选择最佳安装的证书MySubjectName

按照Jeff's Blog上的代码,签名步骤需要定义 pfx 文件名和密码以创建X509Certificate2用于签名的文件:

 private static void SignAllParts(Package package, string pfx, string password, string timestamp){
  var signatureManager = new PackageDigitalSignatureManager(package);
  signatureManager.CertificateOption = CertificateEmbeddingOption.InSignaturePart;

  /*...*/

  signatureManager.Sign(toSign, new System.Security.Cryptography.X509Certificates.X509Certificate2(pfx, password));
}

是否有任何涉及PackageDigitalSignatureManager的 API 可以让我找到一个X509Certificate基础,MySubjectName以便我可以签署反对?

4

1 回答 1

1

我通过遍历当前用户商店中的证书解决了这个问题。我按颁发者名称过滤并仅获取有效证书,然后循环匹配的证书并返回第一个与主题名称匹配的证书:

public static X509Certificate2 Find(string issuer, string subject)
{
    var certStore = new X509Store (StoreName.My, StoreLocation.CurrentUser);
    certStore.Open (OpenFlags.ReadOnly);
    var certCollection = certStore.Certificates.Find (X509FindType.FindByIssuerName, issuer, true);

    foreach (var cert in certCollection)
    {
        if (cert.FriendlyName == subject)
        {
            return cert;
        }
    }

    return null;
}
于 2015-03-16T09:25:45.667 回答