gpt4 book ai didi

php - Guzzlehttp - 如何从 Guzzle 6 获取响应的正文?

转载 作者:IT老高 更新时间:2023-10-28 11:45:39 26 4
gpt4 key购买 nike

我正在尝试围绕我公司正在开发的 api 编写一个包装器。它很安静,使用 Postman,我可以将发布请求发送到像 http://subdomain.dev.myapi.com/api/v1/auth/ 这样的端点,并使用用户名和密码作为 POST 数据和我得到了一个 token 。一切都按预期工作。现在,当我尝试从 PHP 中执行相同操作时,我会返回一个 GuzzleHttp\Psr7\Response 对象,但似乎无法像处理 Postman 请求那样在其中的任何地方找到 token 。

相关代码如下:

$client = new Client(['base_uri' => 'http://companysub.dev.myapi.com/']);
$response = $client->post('api/v1/auth/', [
'form_params' => [
'username' => $user,
'password' => $password
]
]);

var_dump($response); //or $resonse->getBody(), etc...

上面代码的输出看起来像(警告,传入的文本墙):

object(guzzlehttp\psr7\response)#36 (6) {
["reasonphrase":"guzzlehttp\psr7\response":private]=>
string(2) "ok"
["statuscode":"guzzlehttp\psr7\response":private]=>
int(200)
["headers":"guzzlehttp\psr7\response":private]=>
array(9) {
["connection"]=>
array(1) {
[0]=>
string(10) "keep-alive"
}
["server"]=>
array(1) {
[0]=>
string(15) "gunicorn/19.3.0"
}
["date"]=>
array(1) {
[0]=>
string(29) "sat, 30 may 2015 17:22:41 gmt"
}
["transfer-encoding"]=>
array(1) {
[0]=>
string(7) "chunked"
}
["content-type"]=>
array(1) {
[0]=>
string(16) "application/json"
}
["allow"]=>
array(1) {
[0]=>
string(13) "post, options"
}
["x-frame-options"]=>
array(1) {
[0]=>
string(10) "sameorigin"
}
["vary"]=>
array(1) {
[0]=>
string(12) "cookie, host"
}
["via"]=>
array(1) {
[0]=>
string(9) "1.1 vegur"
}
}
["headerlines":"guzzlehttp\psr7\response":private]=>
array(9) {
["connection"]=>
array(1) {
[0]=>
string(10) "keep-alive"
}
["server"]=>
array(1) {
[0]=>
string(15) "gunicorn/19.3.0"
}
["date"]=>
array(1) {
[0]=>
string(29) "sat, 30 may 2015 17:22:41 gmt"
}
["transfer-encoding"]=>
array(1) {
[0]=>
string(7) "chunked"
}
["content-type"]=>
array(1) {
[0]=>
string(16) "application/json"
}
["allow"]=>
array(1) {
[0]=>
string(13) "post, options"
}
["x-frame-options"]=>
array(1) {
[0]=>
string(10) "sameorigin"
}
["vary"]=>
array(1) {
[0]=>
string(12) "cookie, host"
}
["via"]=>
array(1) {
[0]=>
string(9) "1.1 vegur"
}
}
["protocol":"guzzlehttp\psr7\response":private]=>
string(3) "1.1"
["stream":"guzzlehttp\psr7\response":private]=>
object(guzzlehttp\psr7\stream)#27 (7) {
["stream":"guzzlehttp\psr7\stream":private]=>
resource(40) of type (stream)
["size":"guzzlehttp\psr7\stream":private]=>
null
["seekable":"guzzlehttp\psr7\stream":private]=>
bool(true)
["readable":"guzzlehttp\psr7\stream":private]=>
bool(true)
["writable":"guzzlehttp\psr7\stream":private]=>
bool(true)
["uri":"guzzlehttp\psr7\stream":private]=>
string(10) "php://temp"
["custommetadata":"guzzlehttp\psr7\stream":private]=>
array(0) {
}
}
}

Postman 的输出类似于:

{
"data" : {
"token" "fasdfasf-asfasdfasdf-sfasfasf"
}
}

很明显,我在使用 Guzzle 中的响应对象时遗漏了一些东西。 Guzzle 响应在请求中指示 200 状态代码,所以我不确定我需要做什么来检索返回的数据。

最佳答案

Guzzle 工具 PSR-7 .这意味着默认情况下它将消息的正文存储在 Stream 中。使用 PHP 临时流。要检索所有数据,您可以使用强制转换运算符:

$contents = (string) $response->getBody();

你也可以这样做

$contents = $response->getBody()->getContents();

这两种方法的区别在于 getContents 返回剩余的内容,因此第二次调用不会返回任何内容,除非您使用 rewind寻找 .

$stream = $response->getBody();
$contents = $stream->getContents(); // returns all the contents
$contents = $stream->getContents(); // empty string
$stream->rewind(); // Seek to the beginning
$contents = $stream->getContents(); // returns all the contents

相反,使用 PHP 的字符串转换操作,它将从流中读取从头到尾的所有数据。

$contents = (string) $response->getBody(); // returns all the contents
$contents = (string) $response->getBody(); // returns all the contents

文档:http://docs.guzzlephp.org/en/latest/psr7.html#responses

关于php - Guzzlehttp - 如何从 Guzzle 6 获取响应的正文?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30549226/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com