Guzzle是一個PHP的HTTP客戶端,用來輕而易舉地發送請求,並集成到我們的WEB服務上。
https://github.com/guzzle/guzzle
- 接口簡單:構建查詢語句、POST請求、分流上傳下載大文件、使用HTTP cookies、上傳JSON數據等等。
- 發送同步或異步的請求均使用相同的接口。
- 使用PSR-7接口來請求、響應、分流,允許你使用其他兼容的PSR-7類庫與Guzzle共同開發。
- 抽象了底層的HTTP傳輸,允許你改變環境以及其他的代碼,如:對cURL與PHP的流或socket並非重度依賴,非阻塞事件循環。
- 中間件系統允許你創建構成客戶端行為。
$client = new GuzzleHttp\Client(); $res = $client->request('GET', 'https://api.github.com/user', [ 'auth' => ['user', 'pass'] ]); echo $res->getStatusCode(); // "200" echo $res->getHeader('content-type'); // 'application/json; charset=utf8' echo $res->getBody(); // {"type":"User"...' // 發送一個異步請求
/異步
//異步
use Psr\Http\Message\ResponseInterface;
use GuzzleHttp\Exception\RequestException;
$client = new \GuzzleHttp\Client([
//'verify', '/path/to/cacert.pem'
//'timeout' => 1,
'verify' => false
]);
$request = new \GuzzleHttp\Psr7\Request('GET', 'http://127.0.0.1/a.php?a=121q'); $promise = $client->sendAsync($request)->then( function (ResponseInterface $res) { echo $res->getStatusCode() . "\n"; }, function (RequestException $e) { //echo $e->getMessage() . "\n"; //echo $e->getRequest()->getMethod(); } ); echo 'hi'; $promise->wait(); //不運行這里,則不會異步訪問。此處的異步還是需要等待執行完。