.NET 如何向 SOAP 客户端请求添加 SSL 证书

4
使用.NET 4.0框架,我正在尝试进行服务器到服务器的HTTPS SOAP服务调用。 在客户端服务器上,我正在尝试添加本地SSL证书,以便接收调用的服务器可以识别我。
我尝试添加的证书不是来自本地机器存储(即使是来自本地机器存储也会出现问题),只是作为一个(.cer)文件放置在我的机器上。
代码运行良好,似乎已经添加了证书,但每次调用时我的System.Net.trace.log文件都会添加以下错误: “无法在LocalMachine存储或CurrentUser存储中找到证书。”并且我尝试调用的服务器告诉我没有证书附加到我的请求上。 我得到的最终WebException是: “请求被中止:无法创建SSL/TLS安全信道。” 我的GetCertificate函数:
private X509Certificate2 GetCertificate()
{
    X509Certificate2 cert;
    try
    {
        cert = new X509Certificate2("MyCertificateFoder\\MyCertificate.cer");
    }
    catch (Exception ex)
    {
        throw;
    }
    return cert;
}

服务调用代码:

X509Certificate2 cert = GetCertificate();
ServiceClient.ClientCertificates.Add(cert);
serviceMethodResponse = ServiceClient.ServiceMethod(serviceMethodRequest);

希望得到任何建议。

谢谢。

1个回答

3
这里的主要错误是,在使用SSL与客户端身份验证时,应使用.pfx文件(包含客户端私钥、证书、证书链、根证书)。而不是.cer文件。
这就是错误的原因。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接