Google Analytics 如何使用 php 获取服务器到服务器 OAuth 的访问令牌

Rob*_*ach 3 google-analytics oauth

我正在尝试为 Google Analytics 数据创建仪表板,但我不知道如何组合脚本。

我必须像这样使用服务器到服务器身份验证https://developers.google.com/analytics/devguides/config/mgmt/v3/quickstart/service-php但我无法获得我的 Javascript 身份验证的访问令牌

gapi.analytics.auth.authorize({
   serverAuth: {
      access_token: >>How to get an Access token from PHP<<
   }
});
Run Code Online (Sandbox Code Playgroud)

如果我只是做这样的事情

$KEY_FILE_LOCATION = __DIR__ . '/Service.json';
$client = new Google_Client();
$client->setApplicationName("Hello Analytics Reporting");
$client->setAuthConfig($KEY_FILE_LOCATION);
$client->setScopes(['https://www.googleapis.com/auth/analytics.readonly']);
var_dump($client->getAccessToken())
Run Code Online (Sandbox Code Playgroud)

我的 getAccessToken 始终为 NULL 有没有其他方法可以通过服务器到服务器的连接接收访问令牌?我必须找到不需要通过 Javascript 登录的方法,因为来自内容管理系统的所有后端用户都应该能够看到数据。

非常感谢。我是新来的,如果你能解释它是如何工作的,而不仅仅是发送一个链接,那就太好了

编辑:换句话说,这里是我的整个代码......为什么它不起作用,有什么问题?请帮我

    <?php

// Load the Google API PHP Client Library.
require_once __DIR__ . '/vendor/autoload.php';

$accessToken = initializeAnalytics();

function initializeAnalytics()
{
  $KEY_FILE_LOCATION = __DIR__ . '/Service.json';

  $client = new Google_Client();
  $client->setApplicationName("Hello Analytics Reporting");
  $client->setAuthConfig($KEY_FILE_LOCATION);
  $client->setScopes(['https://www.googleapis.com/auth/analytics.readonly']);
  $accessToken = $client->getAccessToken();
  return $accessToken;
}

?>

<script>
    (function(w,d,s,g,js,fjs){
      g=w.gapi||(w.gapi={});g.analytics={q:[],ready:function(cb){this.q.push(cb)}};
      js=d.createElement(s);fjs=d.getElementsByTagName(s)[0];
      js.src='https://apis.google.com/js/platform.js';
      fjs.parentNode.insertBefore(js,fjs);js.onload=function(){g.load('analytics')};
    }(window,document,'script'));
</script>


<div id="chart-1-container"></div>

<script>
    gapi.analytics.ready(function() {
        gapi.analytics.auth.authorize({
          serverAuth: {
            access_token: '<?php echo $accessToken ?>'
          }
        });

        var dataChart = new gapi.analytics.googleCharts.DataChart({
            query: {
                ids: "ga:128053216",
                metrics: 'ga:sessions',
                dimensions: 'ga:date',
                'start-date': '30daysAgo',
                'end-date': 'yesterday',
            },
            chart: {
                container: 'chart-1-container',
                type: 'LINE',
            }
        });
        dataChart.execute();
    });
</script>
Run Code Online (Sandbox Code Playgroud)

Rob*_*ach 5

经过几天的尝试终于找到了解决方案......它现在可以使用这个脚本

    <?php

// Load the Google API PHP Client Library.
require_once __DIR__ . '/vendor/autoload.php';

$accessToken = initializeAnalytics();

function initializeAnalytics()
{
  $KEY_FILE_LOCATION = __DIR__ . '/Service.json';

  $client = new Google_Client();
  $client->setApplicationName("Hello Analytics Reporting");
  $client->setAuthConfig($KEY_FILE_LOCATION);
  $client->setScopes(['https://www.googleapis.com/auth/analytics.readonly']);

  $client->refreshTokenWithAssertion();
  $token = $client->getAccessToken();
  $accessToken = $token['access_token'];

  return $accessToken;
}

?>

<script>
    (function(w,d,s,g,js,fjs){
      g=w.gapi||(w.gapi={});g.analytics={q:[],ready:function(cb){this.q.push(cb)}};
      js=d.createElement(s);fjs=d.getElementsByTagName(s)[0];
      js.src='https://apis.google.com/js/platform.js';
      fjs.parentNode.insertBefore(js,fjs);js.onload=function(){g.load('analytics')};
    }(window,document,'script'));
</script>


<div id="chart-1-container"></div>

<script>
    gapi.analytics.ready(function() {
        gapi.analytics.auth.authorize({
          serverAuth: {
            access_token: '<?php echo $accessToken ?>'
          }
        });

        var dataChart = new gapi.analytics.googleCharts.DataChart({
            query: {
                ids: ">your analytics ID<",
                metrics: 'ga:sessions',
                dimensions: 'ga:date',
                'start-date': '30daysAgo',
                'end-date': 'yesterday',
            },
            chart: {
                container: 'chart-1-container',
                type: 'LINE',
            }
        });
        dataChart.execute();
    });
</script>
Run Code Online (Sandbox Code Playgroud)