Проблемы WebClient + HTTPS - PullRequest
       34

Проблемы WebClient + HTTPS

62 голосов
/ 11 февраля 2009

Я в настоящее время интегрируюсь с системой, созданной третьей стороной. Эта система требует, чтобы я отправил запрос, используя XML / HTTPS. Сторонние отправляют мне сертификат и я его установил

Я использую следующий код:

using (WebClient client = new WebClient())
{
   client.Headers.Add(HttpRequestHeader.ContentType, "text/xml");

   System.Text.ASCIIEncoding  encoding=new System.Text.ASCIIEncoding();
   var response = client.UploadData(address, "POST", encoding.GetBytes(msg));
}

Этот код возвращает следующее WebException:

Базовое соединение было закрыто: не удалось установить доверительные отношения для безопасного канала SSL / TLS.

ОБНОВЛЕНИЕ Поскольку это тестовый сервер, с которым я работаю, сертификат не является доверенным и проверка не проходит ... Чтобы обойти это в среде тестирования / отладки, создайте новый ServerCertificateValidationCallback

ServicePointManager.ServerCertificateValidationCallback += new System.Net.Security.RemoteCertificateValidationCallback(bypassAllCertificateStuff);

и вот мой "поддельный" обратный вызов

private static bool bypassAllCertificateStuff(object sender, X509Certificate cert, X509Chain chain, System.Net.Security.SslPolicyErrors error)
{
   return true;
}

Подробнее здесь и здесь

Ответы [ 3 ]

70 голосов
/ 04 апреля 2011

Кратчайшее обозначение кода, разрешающего все сертификаты, на самом деле:

ServicePointManager.ServerCertificateValidationCallback = delegate { return true; };

И хорошо работает для этой ошибки. Само собой разумеется, что вы должны предоставить реализацию, которая на самом деле проверяет сертификат и на основе информации о сертификате решает, безопасна ли связь. Для тестирования используйте приведенную выше строку кода.

8 голосов
/ 02 октября 2010

Для версии VB.NET оригинального ответа, вы идете (конвертеры не работают хорошо, когда нужно соединить события с оператором 'AddressOf'). Первый код, который идет перед использованием объекта WebClient () или HttpWebRequest ():

ServicePointManager.ServerCertificateValidationCallback = New System.Net.Security.RemoteCertificateValidationCallback(AddressOf bypassAllCertificateStuff)

.. и код метода подключения:

Private Shared Function bypassAllCertificateStuff(ByVal sender As Object, ByVal cert As X509Certificate, ByVal chain As X509Chain, ByVal [error] As System.Net.Security.SslPolicyErrors) As Boolean
    Return True
End Function
0 голосов
/ 25 апреля 2012

Попробуйте, все работает:

class Ejemplo
{
    static void Main(string[] args)
    {
        string _response = null;
        string _auth = "Basic";
        Uri _uri = new Uri(@"http://api.olr.com/Service.svc");

        string addres = @"http://api.olr.com/Service.svc";
        string proxy = @"http://xx.xx.xx.xx:xxxx";
        string user = @"platinum";
        string pass = @"01CFE4BF-11BA";


        NetworkCredential net = new NetworkCredential(user, pass);
        CredentialCache _cc = new CredentialCache();

        WebCustom page = new WebCustom(addres, proxy);
        page.connectProxy();

        _cc.Add(_uri, _auth, net);

        page.myWebClient.Credentials = _cc;

        Console.WriteLine(page.copyWeb());
    }

}

public class WebCustom
{
        private string proxy;
        private string url;
        public WebClient myWebClient;
        public WebProxy proxyObj;
        public string webPageData;


        public WebCustom(string _url, string _proxy)
        {
            url = _url;
            proxy = _proxy;
            myWebClient = new WebClient();
        }

        public void connectProxy()
        {
            proxyObj = new WebProxy(proxy, true);
            proxyObj.Credentials = CredentialCache.DefaultCredentials;
            myWebClient.Proxy = proxyObj;
        }

        public string copyWeb()
        { return webPageData = myWebClient.DownloadString(url); }
}
...