Pergunta

Como posso desligar revogação de certificado para um cliente do serviço WCF? O proxy do cliente foi gerado por wsdl.exe e herda SoapHttpClientProtocol.

Foi útil?

Solução

Eu acho que você está procurando ServicePointManager.ServerCertificateValidationCallback:

http://msdn.microsoft.com /en-gb/library/system.net.servicepointmanager.servercertificatevalidationcallback.aspx

O que leva um RemoteCertificateValidationCallback Delegado:

http://msdn.microsoft.com /en-gb/library/system.net.security.remotecertificatevalidationcallback.aspx

Eu nunca lidei com um certificado revogado antes (eu tenho a mão para lidar com outras questões, como expirado SSL de), mas eu estou supondo que você tinha acabado de fazer algo como:

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;
    }
}

Outras dicas

Você pode definir a validação de certificados e opções de revogação no arquivo de configuração para sua aplicação:

http: // www .request-response.com / blog / permalink, guid, e9bb929b-d0b4-4626-b302-1d2715fc344a.aspx

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top