У меня есть следующий код:
<?php
$cookie_file_path = "cookie.txt"; //
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'theurl');
curl_setopt($ch, CURLOPT_POSTFIELDS,'blocPnr_textField_labelNom='.urlencode('www').'&blocPnr_textField_labelPnr='.urlencode('xxx').'&blocPnr_valider=Submit');
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_SSLVERSION,3);
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file_path);
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file_path);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.3) Gecko/20070309 Firefox/2.0.0.3");
curl_setopt($ch, CURLOPT_REFERER, "theurl");
$page = curl_exec($ch);
var_dump($page);
echo 'error:' . curl_error($ch);
?>
Это дает мне следующую ошибку:
ошибка bool (false): ошибка: 14094410: процедуры SSL: SSL3_READ_BYTES: ошибка квитирования оповещения sslv3
Я не могу понять, откуда взялся ПБ. Я искал подобное сообщение об ошибке в Google и S / O, но не нашел никакого решения.
Вы пытаетесь использовать версию 3 протокола SSL, которая либо отклонена, либо не поддерживается сервером. Атака пуделя заставил многих системных администраторов отказаться от поддержки SSLv3, и его использование уже не так широко распространено (и определенно не рекомендуется).
Когда у вас есть ошибки рукопожатия SSL, попробуйте разные версии SSL / TLS пока один не работает (желательно самый безопасный). Если у вас есть сомнения, используя CURL_SSLVERSION_DEFAULT
работает в большинстве случаев.
curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_DEFAULT);
Кажется, что formulaire.sncf.com поддерживает TLSv1.0. Вы также можете принудительно использовать эту версию протокола:
curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1_0);
Других решений пока нет …