Amphp Artax bug

Я использовал следующий очень простой пример amphp / artax

$ URL может быть любым URL, например, http://www.yahoo.com/

$promises[$URI] = Amp\call(function () use ($client, $URI) {
                // "yield" inside a coroutine awaits the resolution of the promise
                // returned from Client::request(). The generator is then continued.
                $response = yield $client->request($URI);

                // Same for the body here. Yielding an Amp\ByteStream\Message
                // buffers the entire message.
                $body = yield $response->getStatus();

                return $body;
            });

        $responses = Amp\Promise\wait(Amp\Promise\all($promises));

и получить следующую ошибку

    Fatal error: Uncaught Amp\Socket\CryptoException: Crypto negotiation failed: stream_socket_enable_crypto(): SSL operation failed with code 1. OpenSSL Error messages:
error:1414D172:SSL routines:tls12_check_peer_sigalg:wrong signature type in /var/www/html/vendor/amphp/socket/src/Internal/functions.php:118
Stack trace:
#0 /var/www/html/vendor/amphp/amp/lib/Loop/NativeDriver.php(172): Amp\Socket\Internal\{closure}('am', Resource id #293, Object(Amp\Deferred))
#1 /var/www/html/vendor/amphp/amp/lib/Loop/NativeDriver.php(68): Amp\Loop\NativeDriver->selectStreams(Array, Array, 4.782)
#2 /var/www/html/vendor/amphp/amp/lib/Loop/Driver.php(130): Amp\Loop\NativeDriver->dispatch(true)
#3 /var/www/html/vendor/amphp/amp/lib/Loop/Driver.php(70): Amp\Loop\Driver->tick()
#4 /var/www/html/vendor/amphp/amp/lib/Loop.php(76): Amp\Loop\Driver->run()
#5 /var/www/html/vendor/amphp/amp/lib/functions.php(158): Amp\Loop::run(Object(Closure))
#6 /var/www/html/parseradvance.php(77): Amp\Promise\wait(Object(Amp\Internal\PrivatePromise))
#7 {main}
  t in /var/www/html/vendor/amphp/socket/src/Internal/functions.php on line 118

кто-нибудь может помочь мне решить проблему, которую я уже поставил cainfo=curl.pem

заранее спасибо

1 ответ

Решение

Это вызвано тем, что сервер настроен со слабыми шифрами, которые Артакс по умолчанию отклоняет. Слабые шифры могут быть разрешены путем передачи пользовательских ClientTlsContext экземпляр клиенту на создание и настройку withSecurityLevel(1), который по умолчанию 2, Смотрите также https://github.com/amphp/artax/issues/174.

Может быть, это происходит потому, что вы используете http: вместо https:,

Другие вопросы по тегам