Я намагаюся встановити з'єднання SSL / TLS з тестовим сервером із самопідписаним сертифікатом . Зв'язок через незахищений канал працював без проблем.
Ось мій зразок коду, який я написав на основі таких рішень: Дозвіл ненадійних сертифікатів SSL за допомогою HttpClient C # Ігнорувати помилки сертифіката? Клієнт .NET, що підключається до веб-API ssl
ServicePointManager.ServerCertificateValidationCallback += (sender, cert, chain, sslPolicyErrors) => true;
var c = new HttpClient();
var r = c.GetAsync("https://10.3.0.1:8443/rest/v1").Result;
if (r.IsSuccessStatusCode)
{
Log.AddMessage(r.Content.Get<string>());
}
else
{
Log.AddMessage(string.Format("{0} ({1})", (int)r.StatusCode, r.ReasonPhrase));
}
також спробував це:
var handler = new WebRequestHandler();
handler.ServerCertificateValidationCallback = delegate { return true; };
var c = new HttpClient(handler);
...
і це
ServicePointManager.ServerCertificateValidationCallback = delegate { return true; };
але кожного разу я маю виняток:
InnerException: System.Net.Http.HttpRequestException
_HResult=-2146233088
_message=An error occurred while sending the request.
HResult=-2146233088
IsTransient=false
Message=An error occurred while sending the request.
InnerException: System.Net.WebException
_HResult=-2146233079
_message=The request was aborted: Could not create SSL/TLS secure channel.
HResult=-2146233079
IsTransient=false
Message=The request was aborted: Could not create SSL/TLS secure channel.
Source=System
StackTrace:
at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)
at System.Net.Http.HttpClientHandler.GetResponseCallback(IAsyncResult ar)
InnerException:
Що я роблю не так? Чому я не можу підключитися до цього сервера (який має недійсний самопідписаний сертифікат)