2

我正在尝试将以下查询 shopware5 API 的工作 HTTP_Request2 代码移植到 Guzzle 7

$request = new \HTTP_Request2();
$request->setBody('{"limit": 500000}');
$request->setUrl($URL.'/customers');

$request->setMethod(\HTTP_Request2::METHOD_GET);
$request->setHeader('Accept-Encoding','gzip, deflate, br');
$request->setAuth($username, $apiKey, \HTTP_Request2::AUTH_DIGEST);
$response = $request->send();

我尝试了以下操作,但失败并显示消息“无效或缺少身份验证”

$RESTClient = new Client();
        $request = new Guzzle_request(
            'GET',
            $URL  .'/customers',
            [
                'body' => '{"limit": 500000}',
                'decode_content' => 'gzip, deflate, br',
                'auth' => [$username, $apiKey, 'digest']
            ]);
 $response = $RESTClient->send($request);
4

1 回答 1

1

您需要更改您的代码

use GuzzleHttp\Psr7\Request;

$client = new GuzzleHttp\Client();
$headers = ['Accept-Encoding' => 'gzip, deflate, br'];
$body = '{"limit": 500000}';
$request = new Request('GET', $URL . '/customers', $headers, $body);
$response = $client->send($request, [
                                  'verify' => false,
                                  'auth' => [$username, $apiKey, 'digest']  
                              ]);

由于 Digest 具有 md5,因此验证为 false 并不会使其不安全,但我没有在任何地方找到它为什么写的原因,但已经看到摘要仅适用于验证为 false。

您也可以继续在那里使用decode_content没有问题,尽管默认情况下它是 true,所以如果我通过标题,那么我想没有问题。

于 2021-02-25T06:44:31.787 回答