workerman/http-client
最新稳定版本:v3.0.5
Composer 安装命令:
composer require workerman/http-client
包简介
README 文档
README
Asynchronous http client for PHP based on workerman.
-
Asynchronous requests.
-
Uses PSR-7 interfaces for requests, responses.
-
Build-in connection pool.
-
Support Http proxy.
-
Parallel Request. (use 'revolt/event-loop')
Installation
composer require workerman/http-client
Examples
example.php
<?php use Workerman\Worker; require_once __DIR__ . '/vendor/autoload.php'; $worker = new Worker(); $worker->onWorkerStart = function () { $http = new Workerman\Http\Client(); $http->get('https://example.com/', function ($response) { var_dump($response->getStatusCode()); echo $response->getBody(); }, function ($exception) { echo $exception; }); $http->post('https://example.com/', ['key1' => 'value1', 'key2' => 'value2'], function ($response) { var_dump($response->getStatusCode()); echo $response->getBody(); }, function ($exception) { echo $exception; }); $http->request('https://example.com/', [ 'method' => 'POST', 'version' => '1.1', 'headers' => ['Connection' => 'keep-alive'], 'data' => ['key1' => 'value1', 'key2' => 'value2'], 'success' => function ($response) { echo $response->getBody(); }, 'error' => function ($exception) { echo $exception; } ]); }; Worker::runAll();
Run with commands php example.php start or php example.php start -d
Optinons
<?php require __DIR__ . '/vendor/autoload.php'; use Workerman\Worker; $worker = new Worker(); $worker->onWorkerStart = function(){ $options = [ 'max_conn_per_addr' => 128, 'keepalive_timeout' => 15, 'connect_timeout' => 30, 'timeout' => 30, ]; $http = new Workerman\Http\Client($options); $http->get('http://example.com/', function($response){ var_dump($response->getStatusCode()); echo $response->getBody(); }, function($exception){ echo $exception; }); }; Worker::runAll();
Proxy
require __DIR__ . '/vendor/autoload.php'; use Workerman\Worker; $worker = new Worker(); $worker->onWorkerStart = function(){ $options = [ 'max_conn_per_addr' => 128, 'keepalive_timeout' => 15, 'connect_timeout' => 30, 'timeout' => 30, // 'context' => [ // 'http' => [ // // All use '$http' will cross proxy. The highest priority here. !!! // 'proxy' => 'http://127.0.0.1:1080', // ], // ], ]; $http = new Workerman\Http\Client($options); $http->request('https://example.com/', [ 'method' => 'GET', 'proxy' => 'http://127.0.0.1:1080', // 'proxy' => 'socks5://127.0.0.1:1081', 'success' => function ($response) { echo $response->getBody(); }, 'error' => function ($exception) { echo $exception; } ]); }; Worker::runAll();
Parallel
This feature requires http-client version >= v3.0 . When using the fiber driver, you must install revolt/event-loop.
use Workerman\Worker; use Workerman\Events\Fiber; use Workerman\Events\Swoole; use Workerman\Events\Swow; require_once __DIR__ . '/vendor/autoload.php'; $worker = new Worker(); $worker->eventLoop = Fiber::class; // or Swoole::class or Swow::class $worker->onWorkerStart = function () { $http = new Workerman\Http\ParallelClient(); $http->batch([ ['http://example.com', ['method' => 'POST', 'data' => ['key1' => 'value1', 'key2' => 'value2']]], ['https://example2.com', ['method' => 'GET']], ]); $http->push('http://example3.com'); $result = $http->await(false); // $result: // [ // [bool $isSuccess = true, Workerman\Http\Response $response], // [bool $isSuccess = false, Throwable $error], // [bool $isSuccess, Workerman\Http\Response $response], // ] }; Worker::runAll();
License
MIT
统计信息
- 总下载量: 68.12k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 54
- 点击次数: 1
- 依赖项目数: 19
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2019-10-21