要将 Guzzle 与 Slim 一起使用,您需要
通过运行 composer 安装它
$ composer require guzzlehttp/guzzle:~6.0
Guzzle installation
Guzzle Quickstart
创建依赖注册,例如
<?php
use GuzzleHttp\Client;
$container = $app->getContainer();
$container['httpClient'] = function ($cntr) {
return new Client();
};
并把它放在当index.php主引导文件被加载时将被执行的地方。
然后在您的代码中,您可以从容器中获取 guzzle 实例
$guzzle = $container->httpClient;
例如,如果您有以下路线
$app->get('/example', App\Controllers\Example::class);
控制器Example如下
<?php
namespace App\Controllers;
use GuzzleHttp\ClientInterface;
use Psr\Http\Message\ServerRequestInterface as Request;
use Psr\Http\Message\ResponseInterface as Response;
class Example
{
private $httpClient;
public function __construct(ClientInterface $httpClient)
{
$this->httpClient = $httpClient;
}
public function __invoke(Request $request, Response $response, array $args)
{
//call api, etc..etc
$apiResponse = $this->httpClient->get('http://api.blabla.org/get');
//do something with api response
return $response;
}
}
要将 guzzle 实例注入Example 控制器,您需要创建它的依赖注册
use App\Controllers\Example;
$container[Example::class] = function ($cntr) {
return new Example($cntr->httpClient);
}
为了加快页面加载速度,如果您是 API 开发人员,请从那里开始。如果您不是 API 开发人员并且无法控制,请尝试考虑是否可以通过删除不必要的 API 调用来减少 API 调用的数量。或者作为最后的手段,将 API 调用响应缓存到存储中,以便您的应用程序稍后检索。
例如使用redis。
您计算 API url 调用的哈希值,包括其查询字符串,并使用哈希值作为访问缓存 API 调用响应的键。