Google OAuth:无法使用授权码获取刷新令牌

Google OAuth: can't get refresh token with authorization code

我正在使用 Google API 客户端 Google Analytics with OAuth 2.0

我阅读此内容以获取刷新令牌,但它没有出现:https://developers.google.com/identity/protocols/OAuth2WebServer#offline

我只得到这个:

{
 "access_token": "ya29.twHFi4LsiF-AITwzCpupMmie-fljyTIzD9lG8y_OYUdEGKSDL7vD8LPKIqdzRwvoQAWd",
 "token_type": "Bearer",
 "expires_in": 3599,
 "id_token": "very long string"
}

代码如下:

Javascript(获取授权码): 有效

gapi.analytics.ready(function() {

    gapi.analytics.auth.authorize({
        container: 'embed-api-auth-container',
        clientid: '257497260674-ji56vq885ohe9cdr1j6u0bcpr6hu7rde.apps.googleusercontent.com',
    });

    gapi.analytics.auth.on('success', function(response) {
        var code = response.code;
        $.ajax({
            url: "getTokensFromCode.php",
            method: "GET",
            data: {
                "code": code
            },
            success: function (tokens) {
                // I can't get refresh token here, only get "access_token" and "id_token"
                console.log(tokens);
            }
        });


    });

});

PHP(用授权码换代币): 不行

// I get the authorization code in Javascript
$code = $_GET['code'];
$redirectURI = "postmessage";

$client = new Google_Client();
$client->setClientId($clientID);
$client->setClientSecret($clientSecret);
$client->setRedirectUri($redirectURI);
$client->addScope(Google_Service_Analytics::ANALYTICS_READONLY);
$client->setAccessType('offline');
$client->setApprovalPrompt('force');
$client->authenticate($code);

$tokens = $client->getAccessToken();
echo $tokens;

我需要 Javascript 中的刷新令牌,这就是我在 Javascript 中获取授权码并发出 Ajax 请求以获取刷新令牌的原因。

您只会在用户第一次授予您的应用访问权限时获得 refresh_token。您需要将 refresh_token 存储在某个地方以便以后使用它。下次用户登录您的应用时,您将不会获得新的刷新令牌。

FWIW:在 Javascript 客户端中使用刷新令牌没有多大意义,因为 Javascript 客户端无法以安全(机密)方式存储它。由于 Javascript 客户端存在于浏览器中,而用户存在于浏览器中,您只需再次将浏览器重定向到授权端点,您将获得一个新的访问令牌(这也是刷新令牌的目的)。 Google 用户的 SSO 会话将确保用户不需要再次登录并且体验是无缝的。

查看@curious_coder的回复

他解释了一种每次都获得刷新令牌的方法 :) 救生员。这个 post 帮助我到达那里,所以我想我会与任何其他试图找到他们的刷新令牌的人分享这个。将此代码的最后两行添加到您的身份验证过程

$client = new Google_Client();
$client->setAuthConfigFile(__DIR__ . '/client_secrets.json');
$client->setRedirectUri('http://' . $_SERVER['HTTP_HOST'] . '/dashboard/oauthcallbacks');
$client->addScope(Google_Service_Analytics::ANALYTICS_READONLY);    
$client->setAccessType('offline'); //To fetch refresh token(Refresh token issued only first time)
$client->setApprovalPrompt('force'); //Adding this will force for refresh token

我还使用 var_dump($tokens) 来获取内容而不是 echo。不记得它在 PHP 中是否有所不同,但 $tokens 将是一个对象数组。