背景:用laravel進(jìn)行分布式開(kāi)發(fā),自己寫(xiě)了一個(gè)業(yè)務(wù)系統(tǒng),還寫(xiě)了一個(gè)用戶中心和其他的信息中心
現(xiàn)在需要做到前端只需要訪問(wèn)業(yè)務(wù)系統(tǒng)的API接口也可以獲取到其他服務(wù)上面的數(shù)據(jù)
找了很多資料,最后查到了Laravel自帶的GuzzleHttp可以達(dá)到我的需求
Guzzle中文文檔:
http://guzzle-cn.readthedocs.io/zh_CN/latest/index.html
引入安裝
在composer.json文件的“require”項(xiàng)中加入
"guzzlehttp/guzzle": "^6.3",
然后命令行執(zhí)行composer install
在項(xiàng)目中的具體用法:
1、在項(xiàng)目某個(gè)地方,我選擇的是在app/Http/Services目錄下面新建一個(gè)APIHelper
?php
namespace App\Http\Services;
class APIHelper
{
public function post($body,$apiStr)
{
$client = new \GuzzleHttp\Client(['base_uri' => 'http://192.168.31.XX:xxx/api/']);
$res = $client->request('POST', $apiStr,
['json' => $body,
'headers' => [
'Content-type'=> 'application/json',
// 'Cookie'=> 'XDEBUG_SESSION=PHPSTORM',
"Accept"=>"application/json"]
]);
$data = $res->getBody()->getContents();
return $data;
}
public function get($apiStr,$header)
{
$client = new \GuzzleHttp\Client(['base_uri' => 'http://192.168.31.XX:xxx/api/']);
$res = $client->request('GET', $apiStr,['headers' => $header]);
$statusCode= $res->getStatusCode();
$header= $res->getHeader('content-type');
$data = $res->getBody();
return $data;
}
}
在項(xiàng)目中主要我用的是post方法,
'Cookie'=> 'XDEBUG_SESSION=PHPSTORM',
這一行加進(jìn)去之后可以使用XDebug進(jìn)行調(diào)試,但是在真正用起來(lái)的時(shí)候不需要在header里面加這一行了
如果是調(diào)用https接口,如果有證書(shū)問(wèn)題,則加入這兩項(xiàng)'verify' => '/full/path/to/cert.pem','verify' => false,不驗(yàn)證證書(shū)。
public static function post_user($body,$apiStr)
{
$client = new \GuzzleHttp\Client(['verify' => '/full/path/to/cert.pem','base_uri' => 'http://xxx.xxx.com/api/']);
$res = $client->request('POST', $apiStr,
['verify' => false,
'json' => $body,
'headers' => [
'Content-type'=> 'application/json']
]);
$data = $res->getBody()->getContents();
$response=json_decode($data);
return $response;
}
2、具體在Controller中使用
public function index(Request $request)
{
$data = $request->json()->all();
$body = $data;
$apiStr = '/api/xxx/list';
$api = new APIHelper();
$res =$api->post($body,$apiStr);
$data = json_decode($res);
$ret=new RetObject();
$ret->retCode='0000';
$ret->retMsg='Success';
$ret->data=$data;
return response()->json($ret);
}
這樣就可以在一個(gè)系統(tǒng)里用GuzzleHttp調(diào)用第三方的API接口了
以上這篇在Laravel中使用GuzzleHttp調(diào)用第三方服務(wù)的API接口代碼就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- Laravel如何實(shí)現(xiàn)適合Api的異常處理響應(yīng)格式
- Laravel5.5+ 使用API Resources快速輸出自定義JSON方法詳解
- laravel接管Dingo-api和默認(rèn)的錯(cuò)誤處理方式
- Laravel實(shí)現(xiàn)ApiToken認(rèn)證請(qǐng)求
- laravel框架 api自定義全局異常處理方法
- laravel dingo API返回自定義錯(cuò)誤信息的實(shí)例
- laravel 配置路由 api和web定義的路由的區(qū)別詳解
- Laravel5.4簡(jiǎn)單實(shí)現(xiàn)app接口Api Token認(rèn)證方法
- 詳解Laravel制作API接口