У меня есть функция Azure, в которой я создал HTTP-клиент. Этому клиенту нужен сертификат. Этот сертификат хранится в Azure KeyVault. В производственной среде я продолжаю получать следующую ошибку в Application Insights функции Azure:
Сообщение: Результат: функция «MyDummyFunction»
Исключение было создано призыв. Исключение: System.Net.Http.HttpRequestException: не удалось установить SSL-соединение, см. внутреннее исключение. ---> System.Security.Authentication.AuthenticationException: аутентификация не удалась, см. внутреннее исключение. ---> Interop+OpenSsl+SslException: SSL-квитирование завершилось с ошибкой OpenSSL — SSL_ERROR_SSL.
Поэтому я создал простое консольное приложение, чтобы выявить проблему (код приведен ниже). ). Но это работает. Имплантация также работает, когда я запускаю функцию Azure локально. Ошибка возникает только при развертывании в живой среде.
Из журналов видно, что функция Azure не может загрузить сертификат из KeyVault (следующая строка журнала не найдена).
Есть идеи?
спасибо
using Azure.Identity;
using Azure.Security.KeyVault.Certificates;
using System.Net.Http.Json;
using System.Net.Mime;
using System.Security.Authentication;
using System.Security.Cryptography.X509Certificates;
using System.Text;
using System.Text.Json;
var certificate = await GetCertificate();
var httpClient = new HttpClient(new HttpClientHandler
{
ClientCertificateOptions = ClientCertificateOption.Manual,
SslProtocols = SslProtocols.Tls12,
ClientCertificates = { certificate },
ServerCertificateCustomValidationCallback = (httpRequestMessage, cert, cetChain, policyErrors) => { return true; }
});
var url = @"https://mydummyurl.com/login";
var json = "{ "login": true }"; //just a dummy json
var httpRequestMessage = new HttpRequestMessage
{
Content = new StringContent(json, Encoding.UTF8, MediaTypeNames.Application.Json),
Method = HttpMethod.Post,
RequestUri = new Uri(url)
};
try
{
var payload = JsonSerializer.Deserialize(json);
var response = await httpClient.PostAsJsonAsync(url, payload);
response.EnsureSuccessStatusCode();
var result = await response.Content.ReadAsStringAsync();
}
catch (Exception ex)
{
Console.WriteLine($"ERROR: {ex.Message}");
}
Console.WriteLine("Done");
Console.ReadKey();
async Task GetCertificate()
{
var client = new CertificateClient(new Uri($"https://mydummykeyvault.vault.azure.net/"), new DefaultAzureCredential())
var response = await client.DownloadCertificateAsync(new DownloadCertificateOptions("MyDummyCertName"));
return response;
}
Подробнее здесь: https://stackoverflow.com/questions/791 ... e-function
Сертификат не установлен или не используется HTTP-клиентом в функции Azure ⇐ C#
Место общения программистов C#
1729947796
Anonymous
У меня есть функция Azure, в которой я создал HTTP-клиент. Этому клиенту нужен сертификат. Этот сертификат хранится в Azure KeyVault. В производственной среде я продолжаю получать следующую ошибку в Application Insights функции Azure:
Сообщение: Результат: функция «MyDummyFunction»
Исключение было создано призыв. Исключение: System.Net.Http.HttpRequestException: не удалось установить SSL-соединение, см. внутреннее исключение. ---> System.Security.Authentication.AuthenticationException: аутентификация не удалась, см. внутреннее исключение. ---> Interop+OpenSsl+SslException: SSL-квитирование завершилось с ошибкой OpenSSL — SSL_ERROR_SSL.
Поэтому я создал простое консольное приложение, чтобы выявить проблему (код приведен ниже). ). Но это работает. Имплантация также работает, когда я запускаю функцию Azure локально. Ошибка возникает только при развертывании в живой среде.
Из журналов видно, что функция Azure не может загрузить сертификат из KeyVault (следующая строка журнала не найдена).
Есть идеи?
спасибо
using Azure.Identity;
using Azure.Security.KeyVault.Certificates;
using System.Net.Http.Json;
using System.Net.Mime;
using System.Security.Authentication;
using System.Security.Cryptography.X509Certificates;
using System.Text;
using System.Text.Json;
var certificate = await GetCertificate();
var httpClient = new HttpClient(new HttpClientHandler
{
ClientCertificateOptions = ClientCertificateOption.Manual,
SslProtocols = SslProtocols.Tls12,
ClientCertificates = { certificate },
ServerCertificateCustomValidationCallback = (httpRequestMessage, cert, cetChain, policyErrors) => { return true; }
});
var url = @"https://mydummyurl.com/login";
var json = "{ "login": true }"; //just a dummy json
var httpRequestMessage = new HttpRequestMessage
{
Content = new StringContent(json, Encoding.UTF8, MediaTypeNames.Application.Json),
Method = HttpMethod.Post,
RequestUri = new Uri(url)
};
try
{
var payload = JsonSerializer.Deserialize(json);
var response = await httpClient.PostAsJsonAsync(url, payload);
response.EnsureSuccessStatusCode();
var result = await response.Content.ReadAsStringAsync();
}
catch (Exception ex)
{
Console.WriteLine($"ERROR: {ex.Message}");
}
Console.WriteLine("Done");
Console.ReadKey();
async Task GetCertificate()
{
var client = new CertificateClient(new Uri($"https://mydummykeyvault.vault.azure.net/"), new DefaultAzureCredential())
var response = await client.DownloadCertificateAsync(new DownloadCertificateOptions("MyDummyCertName"));
return response;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79128595/certificate-not-set-or-used-by-http-client-in-azure-function[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия