Мой код выглядит так:
Код: Выделить всё
HttpWebRequest request = (HttpWebRequest)WebRequest.Create("https://someapi/request/");
request.Method = "POST";
request.ContentType = "application/json";
request.ContentLength = Encoding.UTF8.GetByteCount(postData);
request.KeepAlive = false;
request.ProtocolVersion = HttpVersion.Version11;
ServicePointManager.Expect100Continue = false;
ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls12;
X509Certificate2 certificate = new X509Certificate2(@"d:\TLScertificate.p12", "password");
X509Store store = new X509Store(StoreName.My, StoreLocation.LocalMachine);
try
{
store.Open(OpenFlags.ReadWrite);
if (!store.Certificates.Contains(certificate))
{
store.Add(certificate);
}
int indexOfCertificate = store.Certificates.IndexOf(certificate);
certificate = store.Certificates[indexOfCertificate];
}
finally
{
store.Close();
}
request.ClientCertificates.Add(certificate);
request.PreAuthenticate = true;
using (StreamWriter writer = new StreamWriter(request.GetRequestStream())) // Exception
{
}
Провайдер ответил мне, что:
Так должно быть,
Root Ca v1 test.pem в вашем хранилище доверенных сертификатов и
TLSCertificate в вашем хранилище ключей
Пожалуйста, сообщите мне, что мне делать с файлом .pem? Его надо добавить в запрос, так же, как и файл TLScertificate.p12? Когда я добавляю в запрос второй сертификат X509Certificate2 (без пароля), я все равно получаю ту же ошибку.
Подробнее здесь: https://stackoverflow.com/questions/351 ... was-aborte