【发布时间】:2015-08-09 13:29:39
【问题描述】:
我尝试加载 x509 证书以在 WCF 客户端中使用。为此,我使用SetDefaultCertificate 函数,但该函数抛出异常。
var clientWS = new WS_eFacturaSoapPortClient();
clientWS.ClientCredentials.ServiceCertificate.SetDefaultCertificate(
StoreLocation.CurrentUser, StoreName.My,
X509FindType.FindBySubjectKeyIdentifier, "79852b4fab95e8cd1f6e36167bbb895bd4cbe767");
例外:
使用以下搜索条件找不到 X.509 证书:
StoreName 'My',StoreLocation 'CurrentUser',FindType
'FindBySubjectKeyIdentifier', FindValue
'79852b4fab95e8cd1f6e36167bbb895bd4cbe767'。
但如果我这样做......
X509Certificate2 cert = null;
X509Store store = new X509Store(StoreName.My, StoreLocation.CurrentUser);
try
{
store.Open(OpenFlags.ReadOnly);
X509Certificate2Collection col = store.Certificates.Find(
X509FindType.FindBySubjectKeyIdentifier, "79852b4fab95e8cd1f6e36167bbb895bd4cbe767", true);
cert = col[0];
}
// Cerrar el store
finally { store.Close(); }
证书成立。
我做错了什么?是否可以将 x509Certificate2 添加到 ClientCredentials?
【问题讨论】: