Ho problemi a curvare un URL HTTPS che utilizza TLS1.2, nella mia operazione di arricciamento pubblico i miei dati di accesso nel sito Web e li salvo in cookiefile. Il messaggio di errore che sto ottenendo questoTLS 1.2 non funziona in cURL
error:14077438:SSL routines:SSL23_GET_SERVER_HELLO:tlsv1 alert internal error
Ho provato a fissare VERIFYPEER
e VERIFYHOST
-0, ma che non sembra funzionare, qualche suggerimento?
Qui ci sono le versioni che sto usando:
- versione OpenSSL è 0.9.8b
- versione CURL è 7.24.0
- PHP è 5,3
Ecco il codice:
$setuplogin = curl_init();
curl_setopt ($setuploginurl, CURLOPT_URL, $url);
curl_setopt ($setuploginurl, CURLOPT_SSL_VERIFYPEER, 1);
curl_setopt ($setuploginurl, CURLOPT_SSL_VERIFYHOST, 1);
curl_setopt ($setuploginurl, CURLOPT_FOLLOWLOCATION, TRUE);
curl_setopt ($setuploginurl, CURLOPT_SSLVERSION, 'CURL_SSLVERSION_TLSv1_2');
curl_setopt ($setuploginurl, CURLOPT_POSTFIELDS, 'username=uname&password=pword&act=login&submit=Login');
curl_setopt ($setuploginurl, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.135 Safari/537.36");
curl_setopt (setuploginurl, CURLOPT_TIMEOUT, 60);
curl_setopt ($setuploginurl, CURLOPT_COOKIESESSION, TRUE);
curl_setopt ($setuploginurl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt ($setuploginurl, CURLOPT_HEADER, 1);
curl_setopt ($setuploginurl,CURLOPT_ENCODING,"gzip");
curl_setopt ($setuploginurl, CURLOPT_POST, true);
curl_setopt ($setuploginurl, CURLOPT_COOKIEJAR, 'cookies.txt');
curl_setopt ($setuploginurl, CURLOPT_FRESH_CONNECT , 1);
$loginp= curl_exec($setuploginurl);
if ($loginp === FALSE) {
die(curl_error($setuploginurl));
}
curl_close ($setuploginurl);
var_dump ($loginp);
Si consiglia di utilizzare 2 per CURLOPT_SSL_VERIFYHOST, non 1. – Bruno
Non so se questo è automatico ma passare a PHP v 5.6.33 ha risolto il problema . –