Eseguo un'applicazione nell'applicazione di Azure Standard: 1 Piano piccolo. Framework is 4.6.1Solo su azzurro: Impossibile creare il canale protetto SSL/TLS
Questa applicazione sta chiamando un'API protetta SSL. Il protocollo SSL è pubblicato da StartCom Class 1 DV Server CA, il mio browser locale mi dice che il certificato è valido.
Se eseguo l'applicazione sul mio computer locale, tutto funziona. Tuttavia, quando schierato all'azzurro non riesce con l'errore follwing:
System.Net.Http.HttpRequestException: An error occurred while sending the request. ---> System.Net.WebException: The request was aborted: Could not create SSL/TLS secure channel.
at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)
at System.Net.Http.HttpClientHandler.GetResponseCallback(IAsyncResult ar)
--- End of inner exception stack trace ---
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
Il codice:
public async Task<List<QutationOverview>> GetAll(string url, DateTime lastActionDate)
{
var result = string.Empty;
try
{
var userName = await _settingManager.GetSettingValueAsync("API.UserName");
var password = await _settingManager.GetSettingValueAsync("API.Password");
ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls |
SecurityProtocolType.Tls11 | SecurityProtocolType.Tls12;
ServicePointManager
.ServerCertificateValidationCallback +=
(sender, cert, chain, sslPolicyErrors) => true;
//Add date filter
//Always request qutations where the last action took place >= Yesterday
var requestUrl =
$"GetALL/?last_action_date={lastActionDate.AddDays(-1).ToString("yyyy-MM-dd")}&format=json";
var baseAddress = new Uri(url);
var credentials = Convert.ToBase64String(Encoding.ASCII.GetBytes($"{userName}:{password}"));
Logger.InfoFormat("GetAllQuotationsAsync for url {0}{1}", url, requestUrl);
using (var httpClient = new HttpClient {BaseAddress = baseAddress})
{
httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Basic", credentials);
using (var response = await httpClient.GetAsync(requestUrl))
{
result = await response.Content.ReadAsStringAsync();
Logger.Info(result);
}
}
}
catch (Exception ex)
{
Logger.ErrorFormat("GetAllQuotationsAsync {0}: {1}", url, ex);
}
var data = JsonConvert.DeserializeObject<List<QutationOverview>>(result);
return data;
}
Come potete vedere ho saltare la convalida del certificato e ha aggiunto i protocolli di sicurezza.
Tuttavia, la richiesta continua a non riuscire.
Ecco la risposta caputred http://textuploader.com/5ers0
Avete qualche idea di come ottenere questo lavoro su Azure?
correlati: http: // StackOverflow.it/questions/34437473/could-not-create-ssl-tls-secure-channel-in-an-azure-web-application? rq = 1 –
Il link textuploader.com è ora rotto. –