如何关闭WCF服务客户端的证书吊销?
-
03-07-2019 - |
题
如何关闭WCF服务客户端的证书吊销? 客户端代理由wsdl.exe生成并继承SoapHttpClientProtocol。
解决方案
我认为您正在寻找 ServicePointManager.ServerCertificateValidationCallback
:
其中 RemoteCertificateValidationCallback
代表:
我以前从未处理过撤销的证书(我有办法解决其他问题,例如过期的SSL),但我猜你只是做了类似的事情:
class Program
{
static void Main(string[] args)
{
ServicePointManager.ServerCertificateValidationCallback +=
new RemoteCertificateValidationCallback(ValidateCertificate);
// Do WCF calls...
}
public static bool ValidateCertificate(object sender, X509Certificate cert,
X509Chain chain, SslPolicyErrors sslPolicyErrors)
{
if(sslPolicyErrors == SslPolicyErrors.RemoteCertificateChainErrors)
{
foreach(X509ChainStatus chainStatus in chain.ChainStatus)
{
if(chainStatus.Status == X509ChainStatusFlags.Revoked)
{
return true;
}
}
}
return false;
}
}
其他提示
您可以在应用程序的配置文件中设置证书验证和吊销选项:
http:// www .request-response.com /博客/ PERMALINK,GUID e9bb929b-d0b4-4626-b302-1d2715fc344a.aspx
不隶属于 StackOverflow