我正在尝试签署一个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
以便我可以签署反对?