以往在項(xiàng)目中要用到第三方接口時(shí)會(huì)用到封裝好的curl執(zhí)行請(qǐng)求,現(xiàn)在有了更好的解決方案——Guzzle。
下面是官方介紹:
Guzzle是一個(gè)PHP的HTTP客戶端,用來(lái)輕而易舉地發(fā)送請(qǐng)求,并集成到我們的WEB服務(wù)上。
接口簡(jiǎn)單:構(gòu)建查詢語(yǔ)句、POST請(qǐng)求、分流上傳下載大文件、使用HTTP cookies、上傳JSON數(shù)據(jù)等等。
發(fā)送同步或異步的請(qǐng)求均使用相同的接口。
使用PSR-7接口來(lái)請(qǐng)求、響應(yīng)、分流,允許你使用其他兼容的PSR-7類庫(kù)與Guzzle共同開(kāi)發(fā)。
抽象了底層的HTTP傳輸,允許你改變環(huán)境以及其他的代碼,如:對(duì)cURL與PHP的流或socket并非重度依賴,非阻塞事件循環(huán)。
中間件系統(tǒng)允許你創(chuàng)建構(gòu)成客戶端行為。
安裝
composer require guzzlehttp/guzzle //用composer安裝最新guzzle,當(dāng)前是6.3版
GET請(qǐng)求示例
$client = new GuzzleHttp\Client(); //初始化客戶端
$response = $client->get('http://httpbin.org/get', [
'query' => [ //get查詢字符串參數(shù)組
'a' => '參數(shù)a的值',
'b' => '參數(shù)b的值',
],
'timeout' => 3.14 //設(shè)置請(qǐng)求超時(shí)時(shí)間
]);
// 與上面一條等價(jià)
// $response = $client->request('GET','http://httpbin.org/get', [
// 'query' => [
// 'a' => '參數(shù)a的值',
// 'b' => '參數(shù)b的值',
// ],
// 'timeout' => 3.14
// ]);
$body = $response->getBody(); //獲取響應(yīng)體,對(duì)象
$bodyStr = (string)$body; //對(duì)象轉(zhuǎn)字串,這就是請(qǐng)求返回的結(jié)果
echo $bodyStr;
類似的請(qǐng)求方法還有:
$response = $client->get('http://httpbin.org/get');
$response = $client->delete('http://httpbin.org/delete');
$response = $client->head('http://httpbin.org/get');
$response = $client->options('http://httpbin.org/get');
$response = $client->patch('http://httpbin.org/patch');
$response = $client->post('http://httpbin.org/post');
$response = $client->put('http://httpbin.org/put');
POST請(qǐng)求示例
$client = new GuzzleHttp\Client();
//普通表單`application/x-www-form-urlencoded`的POST請(qǐng)求
$response = $client->post('http://httpbin.org/post', [
'form_params' => [ //參數(shù)組
'a' => 'aaa',
'b' => 'bbb',
'nested_field' => [ //參數(shù)允許嵌套多層
'A' => 'AAA',
'B' => 'BBB',
]
],
]);
//包含文件上傳的表單`multipart/form-data`的POST請(qǐng)求
// $response = $client->post('http://httpbin.org/post', [
// 'multipart' => [ //注意這個(gè)參數(shù)組的鍵名與前一個(gè)不同
// [
// 'name' => 'a', //字段名
// 'contents' => 'aaa' //對(duì)應(yīng)的值
// ],
// [
// 'name' => 'upload_file_name', //文件字段名
// 'contents' => fopen('/data/test.md', 'r') //文件資源
// ],
// ]
// ]);
$body = $response->getBody(); //獲取響應(yīng)體,對(duì)象
$bodyStr = (string)$body; //對(duì)象轉(zhuǎn)字串
echo $bodyStr;
以上便是Guzzle的POST和GET請(qǐng)求的基本介紹,相信很多時(shí)間掌握這兩個(gè)語(yǔ)法方法已經(jīng)能滿足項(xiàng)目開(kāi)發(fā)的需求了。當(dāng)然這只是強(qiáng)大的Guzzle功能中很小的一部份,感興趣的同學(xué)想深入了解的可以參考官方文檔。希望大家多多支持腳本之家。
Guzzle6中文文檔參考
您可能感興趣的文章:- PHP獲取http請(qǐng)求的頭信息實(shí)現(xiàn)步驟
- php之curl實(shí)現(xiàn)http與https請(qǐng)求的方法
- PHP實(shí)現(xiàn)取得HTTP請(qǐng)求的原文
- php中調(diào)用其他系統(tǒng)http接口的方法說(shuō)明
- PHP 使用header函數(shù)設(shè)置HTTP頭的示例解析 表頭
- php抓取https的內(nèi)容的代碼
- php curl 獲取https請(qǐng)求的2種方法
- 在Laravel中使用GuzzleHttp調(diào)用第三方服務(wù)的API接口代碼
- 使用Zttp簡(jiǎn)化Guzzle 調(diào)用
- PHP的HTTP客戶端Guzzle簡(jiǎn)單使用方法分析