Guzzle-Swoole
Введение
Guzzle-Swoole позволяет Guzzle работать без потерь в среде Swoole-корутин. Для этого не нужно изменять ни одной строки кода сторонних пакетов, достаточно просто обеспечить поддержку корутин.
Поддерживаются версии Guzzle 6.x и 7.x.
Также поддерживаются Composer версий 1.x и 2.x.
Может использоваться в таких SDK, как ElasticSearch и AWS.
Совместим со всеми фреймворками Swoole.
QQ группа: 17916227 
Использование
"yurunsoft/guzzle-swoole":"^2.2"
composer require yurunsoft/guzzle-swoole
<?php
require dirname(__DIR__) . '/vendor/autoload.php';
use GuzzleHttp\Client;
use Yurun\Util\Swoole\Guzzle\SwooleHandler;
use GuzzleHttp\DefaultHandler;
// Добавьте эту строку в точку входа вашего проекта
DefaultHandler::setDefaultHandler(SwooleHandler::class);
go(function(){
$client = new Client();
$response = $client->request('GET', 'http://www.baidu.com', [
'verify' => false,
]);
var_dump($response->getStatusCode());
});
use GuzzleHttp\Client;
use GuzzleHttp\HandlerStack;
use Yurun\Util\Swoole\Guzzle\SwooleHandler;
go(function(){
$handler = new SwooleHandler();
$stack = HandlerStack::create($handler);
$client = new Client(['handler' => $stack]);
$response = $client->request('GET', 'http://www.baidu.com', [
'verify' => false,
]);
var_dump($response->getBody()->__toString(), $response->getHeaders());
});
Более подробные примеры кода можно найти в каталоге test.
$client = \Elasticsearch\ClientBuilder::create()->setHosts(['192.168.0.233:9200'])->setHandler(new \Yurun\Util\Swoole\Guzzle\Ring\SwooleHandler())->build();
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.