Где получить Google Analytics API access_token?

В соответствии с Справочник по Google Analytics API OAuth, а также токен доступа могут быть использованы для доступа к статистике страницы. Использование OAuth довольно сложно или, по крайней мере, мне так кажется в php. Однако, согласно документам, я также должен иметь возможность использовать access_code в качестве параметра get.

Я попробовал несколько способов получить access_token из консоль разработчика Google, но ни один из них не работает, всегда возвращая следующую ошибку:

{"error":{"errors":[{"domain":"global","reason":"required","message":"Login Required","locationType":"header","location":"Authorization"}],"code":401,"message":"Login Required"}}

Таким образом, мне интересно, как получить не истекающий код доступа API для моих свойств страницы Google Analytics? если вообще возможно?

2

Решение

Вам необходимо зарегистрировать заявку на Консоль разработчика Google первый. Это вопрос использования Oauth2 для получения токена доступа. Вы получаете токен доступа, сначала запрашивая у пользователя разрешение на доступ к его данным. После получения разрешения вы получите токен обновления, который вы можете использовать для получения токена доступа.

В следующем примере используется клиентская библиотека Google PHP, найденная на GitHub. Код был скопирован с моего Google Oauth2 PHP Tutorial учебник.

<?php
require_once 'Google/Client.php';
require_once 'Google/Service/Analytics.php';
session_start();
$client = new Google_Client();
$client->setApplicationName("Client_Library_Examples");
$client->setDeveloperKey("{devkey}");
$client->setClientId('{clientid}.apps.googleusercontent.com');
$client->setClientSecret('{clientsecret}');
$client->setRedirectUri('http://www.daimto.com/Tutorials/PHP/Oauth2.php');
$client->setScopes(array('https://www.googleapis.com/auth/analytics.readonly'));

//For loging out.
if ($_GET['logout'] == "1") {
unset($_SESSION['token']);
}

// Step 2: The user accepted your access now you need to exchange it.
if (isset($_GET['code'])) {

$client->authenticate($_GET['code']);
$_SESSION['token'] = $client->getAccessToken();
$redirect = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
header('Location: ' . filter_var($redirect, FILTER_SANITIZE_URL));
}

// Step 1:  The user has not authenticated we give them a link to login
if (!$client->getAccessToken() && !isset($_SESSION['token'])) {
$authUrl = $client->createAuthUrl();
print "<a class='login' href='$authUrl'>Connect Me!</a>";
}

// Step 3: We have access we can now create our service
if (isset($_SESSION['token'])) {
print "<a class='logout' href='".$_SERVER['PHP_SELF']."?logout=1'>LogOut</a><br>";
$client->setAccessToken($_SESSION['token']);
$service = new Google_Service_Analytics($client);

// request user accounts
$accounts = $service->management_accountSummaries->listManagementAccountSummaries();

foreach ($accounts->getItems() as $item) {
echo "Account: ",$item['name'], "  " , $item['id'], "<br /> \n";
foreach($item->getWebProperties() as $wp) {
echo '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;WebProperty: ' ,$wp['name'], "  " , $wp['id'], "<br /> \n";

$views = $wp->getProfiles();
if (!is_null($views)) {
foreach($wp->getProfiles() as $view) {
//  echo '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;View: ' ,$view['name'], "  " , $view['id'], "<br /> \n";
}
}
}
} // closes account summaries

}
print "<br><br><br>";
print "Access from google: " . $_SESSION['token'];
?>
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]