В соответствии с API-интерфейсом API Google Analytics 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? если возможно вообще?
Сначала необходимо зарегистрировать свое приложение на консоли разработчика 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 ' WebProperty: ' ,$wp['name'], " " , $wp['id'], "<br /> \n"; $views = $wp->getProfiles(); if (!is_null($views)) { foreach($wp->getProfiles() as $view) { // echo ' View: ' ,$view['name'], " " , $view['id'], "<br /> \n"; } } } } // closes account summaries } print "<br><br><br>"; print "Access from google: " . $_SESSION['token']; ?>
с<?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 ' WebProperty: ' ,$wp['name'], " " , $wp['id'], "<br /> \n"; $views = $wp->getProfiles(); if (!is_null($views)) { foreach($wp->getProfiles() as $view) { // echo ' View: ' ,$view['name'], " " , $view['id'], "<br /> \n"; } } } } // closes account summaries } print "<br><br><br>"; print "Access from google: " . $_SESSION['token']; ?>