我正在尝试使用guzzle 6,它运行正常,但是当涉及到如何记录所有api调用时我迷失了.我想简单地记录时间,从会话登录用户,网址以及与API调用有关的任何其他常见相关信息.我似乎找不到Guzzle 6引用的任何文档,只有guzzle 3(他们已经更改了日志记录addSubscriber调用).这是我当前的API调用方式:
$client = new GuzzleHttp\Client(['defaults' => ['verify' => false]]);
$res = $client->get($this->url . '/api/details', ['form_params' => ['file' => $file_id]]);
解决方法:
您可以使用任何与Guzzle 6实现PSR-3接口的记录器
在下面的例子中,我使用Monolog作为Logger和内置的Guzzle中间件和MessageFormatter.
use GuzzleHttp\HandlerStack;
use GuzzleHttp\Middleware;
use GuzzleHttp\MessageFormatter;
use Monolog\Logger;
$stack = HandlerStack::create();
$stack->push(
Middleware::log(
new Logger('Logger'),
new MessageFormatter('{req_body} - {res_body}')
)
);
$client = new \GuzzleHttp\Client(
[
'base_uri' => 'http://httpbin.org',
'handler' => $stack,
]
);
echo (string) $client->get('ip')->getBody();
有关日志中间件和消息格式化程序的详细信息尚未详细记录.但是你可以在0730中使用MessageFormatter中可以使用的变量
还有一个guzzle-logmiddleware,它允许您自定义格式化程序等.