Проверка сертификата ByPass SSL с помощью Artax
При отправке запроса POST на сервер с недействительным сертификатом SSL ( Cloudflare должен повторно выдать сертификат), Artax возвращает следующую ошибку:
stream_socket_enable_crypto (): операция SSL не выполнена с кодом 1. OpenSSL Сообщения об ошибках: ошибка:14090086: подпрограммы SSL:SSL3_GET_SERVER_CERTIFICATE: сбой проверки сертификата
Я пытался использовать
$client->setOption('tlsOptions', [
'verify_peer' => FALSE,
]);
а также
$request->setOption('tlsOptions', [
'verify_peer' => FALSE,
]);
Однако в обоих случаях ошибки выбрасываются.
Может кто-нибудь пролить свет на правильный метод, чтобы отключить проверку сверстников с Artax?
Обновить
Я пробовал оба:
$client->setAllOptions([
'tlsOptions' => [
'verify_peer' => FALSE,
'allow_self_signed' => TRUE,
],
]);
А также
$client->setOption('tlsOptions', [
'verify_peer' => FALSE,
'allow_self_signed' => TRUE,
]);
Оба дают мне ответ 400 ( Bad Request).
[status:Artax\Response:private] => 400
[reason:Artax\Response:private] => Bad Request
[protocol:Artax\Message:private] => 1.1
[headers:Artax\Message:private] => Array
(
[Date] => Array
(
[0] => Mon, 19 May 2014 09:50:19 GMT
)
[Server] => Array
(
[0] => Apache/2.4.9 (Ubuntu)
)
[Content-Length] => Array
(
[0] => 303
)
[Connection] => Array
(
[0] => close
)
[Content-Type] => Array
(
[0] => text/html; charset=iso-8859-1
)
)
[headerCaseMap:Artax\Message:private] => Array
(
[DATE] => Date
[SERVER] => Server
[CONTENT-LENGTH] => Content-Length
[CONNECTION] => Connection
[CONTENT-TYPE] => Content-Type
)
2 ответа
С текущим master
филиал, следующий будет обходить проверку:
$client->setOption(Amp\Artax\Client::OP_CRYPTO, [
"verify_peer" => false,
"verify_peer_name" => false
]);
Может быть, разрешение на самоподписание будет работать:
$client->setOption('tlsOptions', [
'verify_peer' => FALSE,
'allow_self_signed' => TRUE,
]);