微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 如何从服务器端后台服务访问Google AnalyticsAPI?

我想通过后台cron作业将谷歌分析中的数据导入自己的数据库,而无需用户每次都进行身份验证.

我确实知道how to get an Google Analytics OAuth Access Token with user interaction,正如我先前所说.使用OAuth不起作用,因为它需要用户交互.根据Google Analytics API Reference,OAuth以及访问令牌可用于在每个会话基础上访问一次页面统计数据.但是,我正在寻找一种在后台服务中实现这一点的持久方法.

如何在没有用户身份验证的情况下访问Google Analytics(分析)或获取无到期访问令牌?

解决方法:

假设相关帐户是您自己的帐户,则可以使用service account.确保您将帐户级别的服务帐户电子邮件地址读取权限授予Google分析帐户,并且它将能够读取您的数据.

<?PHP
session_start();
require_once 'Google/Client.PHP';
require_once 'Google/Service/Analytics.PHP';

/************************************************
  The following 3 values an befound in the setting
  for the application you created on  Google 
  Developers console.
  The Key file should be placed in a location
  that is not accessable from the web. outside of 
  web root.

  In order to access your GA account you must
  Add the Email address as a user at the 
  ACCOUNT Level in the GA admin. 
 ************************************************/
$client_id = '1046123799103-nk421gjc2v8mlr2qnmmqaak04ntb1dbp.apps.googleusercontent.com';
$Email_address = '1046123799103-nk421gjc2v8mlr2qnmmqaak04ntb1dbp@developer.gserviceaccount.com';
$key_file_location = '629751513db09cd21a941399389f33e5abd633c9-privatekey.p12';

$client = new Google_Client();
$client->setApplicationName("Client_Library_Examples");

$key = file_get_contents($key_file_location);

// seproate additional scopes with a comma
$scopes ="https://www.googleapis.com/auth/analytics.readonly";  

$cred = new Google_Auth_AssertionCredentials(
    $Email_address,
    array($scopes),
    $key
    );

$client->setAssertionCredentials($cred);
if($client->getAuth()->isAccesstokenExpired()) {
    $client->getAuth()->refreshTokenWithAssertion($cred);
}

$service = new Google_Service_Analytics($client);  
$accounts = $service->management_accountSummaries->listManagementAccountSummaries();

//calulating start date
$date = new DateTime(date("Y-m-d"));
$date->sub(new DateInterval('P10D'));

//Adding Dimensions
$params = array('dimensions' => 'ga:userType');
// requesting the data
$data = $service->data_ga->get("ga:78110423", $date->format('Y-m-d'),  date("Y-m-d"), "ga:users,ga:sessions", $params );


?><html>
<?PHP echo $date->format('Y-m-d') . " - ".date("Y-m-d"). "\n";?>
<table>
<tr>
<?PHP
//Printing column headers
foreach($data->getColumnHeaders() as $header){  
    print "<td>".$header['name']."</td>";   
}
?>
</tr>
<?PHP
//printing each row.
foreach ($data->getRows() as $row) {    
    print "<tr><td>".$row[0]."</td><td>".$row[1]."</td><td>".$row[2]."</td></tr>";  
}

//printing the total number of rows
?>
<tr><td colspan="2">Rows Returned <?PHP print $data->getTotalResults();?> </td></tr>
</table>
</html>
<?PHP

?>

代码从教程Google Service Account with PHP删除

如果这不是您的帐户,那么您可以使用正常的Oauth2方法请求使用身份验证您,然后使用刷新令牌您将能够访问数据.使用上一个问题的代码.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐