6

在 Google Oauth2 实现中,我正在尝试使用 guzzle 调用交换令牌的授权代码。

以下 guzzle 调用工作正常并返回预期值:

 $result = $this->client->post(
        'https://www.googleapis.com/oauth2/v3/token?code=<authorization_code>&redirect_uri=<redirect_uri>&client_id=<client_id>&client_secret=<client_secret>&grant_type=authorization_code')
->getBody()->getContents();

然而,这似乎是挂载发布请求的一种肮脏方式。

我尝试了以下方法以使其更清洁:

    $result = $this->client->post(
        'https://www.googleapis.com/oauth2/v3/token',
        [
            'query' =>
                [
                    'code' => <authorization_code>,
                    'redirect_uri' => <redirect_uri>,
                    'client_id' => <client_id>,
                    'client_secret' => <client_secret>
                    'grant_type' => 'authorization_code',
                ]
        ]
    )->getBody()->getContents();

但是,第二次调用会生成Malformed Json错误消息。

知道我可能做错了什么,或者如何调试上面示例中生成的最终 url?

4

2 回答 2

11

我试过没有code参数,它工作。

$client = new \GuzzleHttp\Client();

$response = $client->post('https://www.googleapis.com/oauth2/v3/token', [
    'query' => [
        'client_id' => '...apps.googleusercontent.com',
        'client_secret' => 'secret',
        'refresh_token' => 'token',
        'grant_type' => 'refresh_token'
    ]
]);

$token = $response->getBody()->getContents()
于 2016-09-07T13:40:47.857 回答
-3

您是否尝试过使用数组和http://php.net/json_encode

于 2016-03-08T09:25:08.197 回答