谷歌API访问令牌PHP


Google API Access Token PHP

我正在验证谷歌分析帐户并成功检索数据。但是,我想每周运行一次cronjob从经过身份验证的帐户获取数据,但是访问令牌无效。

我读过一些关于刷新令牌的东西,但我不确定如何使用它们。我应该在数据库中存储什么数据,以便随时访问经过身份验证的帐户?

要获得访问令牌和刷新令牌,首先创建一个包含以下代码的文件:

<?php
if (isset($_GET['code'])) {
    // try to get an access token
    $code = $_GET['code'];
    $url = 'https://accounts.google.com/o/oauth2/token';
    $params = array(
        "code" => $code,
        "client_id" => YOUR_CLIENT_ID,
        "client_secret" => YOUR_CLIENT_SECRET,
        "redirect_uri" => 'http://' . $_SERVER["HTTP_HOST"] . $_SERVER["PHP_SELF"],
        "grant_type" => "authorization_code"
    );
    $ch = curl_init();
    curl_setopt($ch, constant("CURLOPT_" . 'URL'), $url);
    curl_setopt($ch, constant("CURLOPT_" . 'POST'), true);
    curl_setopt($ch, constant("CURLOPT_" . 'POSTFIELDS'), $params);
    $output = curl_exec($ch);
    $info = curl_getinfo($ch);
    curl_close($ch);
    if ($info['http_code'] === 200) {
        header('Content-Type: ' . $info['content_type']);
        return $output;
    } else {
        return 'An error happened';
    }
} else {
    $url = "https://accounts.google.com/o/oauth2/auth";
    $params = array(
        "response_type" => "code",
        "client_id" => YOUR_CLIENT_ID,
        "redirect_uri" => 'http://' . $_SERVER["HTTP_HOST"] . $_SERVER["PHP_SELF"],
        "scope" => "https://www.googleapis.com/auth/plus.me"
    );
    $request_to = $url . '?' . http_build_query($params);
    header("Location: " . $request_to);
}

然后,将YOUR_CLIENT_IDYOUR_CLIENT_SECRET替换为您的客户端ID和客户端秘密。

确保你的范围是正确的。例如,如果你想访问分析,它应该是https://www.googleapis.com/auth/analytics

如果你运行这段代码,你应该得到一个OAuth2批准屏幕。现在,按下Accept,您应该得到如下的结果:

{
  "access_token" : YOUR_ACCESS_TOKEN,
  "token_type" : "Bearer",
  "expires_in" : 3600,
  "refresh_token" : YOUR_REFRESH_TOKEN
}

结果可能包含额外的字段,这取决于您申请的范围。