Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to get analytics data using google api without login?

I am using php and mysql. I have to get anlytics data of different sites using google sdk api and most important thing is that I need not to login in api. without login I need go get analytics data.
please have a look below code where I am able to get 'Google_AnalyticsService' object and facing error while getting data.It is saying Login Required...

require 'apigp/Google_Client.php';
require 'apigp/contrib/Google_PlusService.php';
require 'apigp/contrib/Google_AnalyticsService.php';

date_default_timezone_set('UTC');
$date_beforeonemoth = date("Y-m-d", mktime(0,0,0,date("m"),date("d")-30,date("Y")));
$date_today = date("Y-m-d", mktime(0,0,0,date("m"),date("d"),date("Y")));

$google = new Google_Client();
$google->setDeveloperKey('Google AppKey here');
$google->setClientSecret('Google ClientSecretKey here');
$google->setClientId('Google ClientID here');
$analytics = new Google_AnalyticsService($google);

$profileURL="";
$pageName="";
$brandId="";
$sql="select * from profiles where APIType='Google Plus'";
$result=mysql_query($sql);
while($rs = mysql_fetch_assoc($result))
{
    $profileURL='https://plus.google.com/105932700878744xxxxxx';
    $brandId=4;
    $pageName=basename($profileURL);

    $accounts = $analytics->management_accounts->listManagementAccounts();
    if(isset($accounts['totalResults'])){
        if($accounts['totalResults']>0){
            $firstAccountId = $accounts['items'][0]['id'];
 $webproperties = $analytics->management_webproperties->listManagementWebproperties($firstAccountId);
                if(count($webproperties['items'])>0){
                     $firstWebpropertyId = $webproperties['items'][0]['id'];
$profiles = $analytics->management_profiles->listManagementProfiles($firstAccountId, $firstWebpropertyId);

                     if (count($profiles['items']) > 0) {
                       $profileId = $profiles['items'][0]['id'];


        $profileId = $pageName;
        $results = $analytics->data_ga->get(
        'ga:' . $profileId,
        $date_beforeonemoth,
        $date_today,
       'ga:visits,ga:pageviews,ga:pageviewsPerVisit,ga:avgTimeOnPage,ga:visitBounceRate,ga:percentNewVisits,ga:uniquePageviews',
        array(
            'dimensions' => 'ga:source,ga:keyword,ga:browser,ga:date,ga:month,ga:day,ga:year',
            'sort' => '-ga:visits,ga:keyword',
           // 'filters' => 'ga:medium==organic',
            'max-results' => '25'));

                       $visits = "";
                       $unique_visitors = "";
                       $pageviews = "";
                       $pages_visit = "";
                       $avg_visit_duration = "";
                       $bounce_rate = "";
                       $new_visits = "";

                       echo "<br>".$visits = $results['totalsForAllResults']['ga:visits'];
                       echo "<br>".$unique_visitors = $results['totalsForAllResults']['ga:uniquePageviews'];
                       echo "<br>".$pageviews = $results['totalsForAllResults']['ga:pageviews'];
                       $pages_visit = $results['totalsForAllResults']['ga:pageviewsPerVisit'];
                       $avg_visit_duration = $results['totalsForAllResults']['ga:avgTimeOnPage'];
                       $bounce_rate = $results['totalsForAllResults']['ga:visitBounceRate'];
                       $new_visits = $results['totalsForAllResults']['ga:percentNewVisits'];

                       $profileName = $results['profileInfo']['profileName'];

                    }else{print"No profiles found for this user.";}

                    }else{print"No webproperties found for this user.";}  //close webproperties result if condition

                }else{print"No accounts found for this user.";} //close total result if condition   
}
}

Error:
Fatal error: Uncaught exception 'Google_ServiceException' with message 'Error calling GET https://www.googleapis.com/analytics/v3/management/accounts?key=AIzaSyBeh0Aevex7q3iRIY5bV3N9gx0WAkNBMi4: (401) Login Required' in E:\xampp\htdocs\DATAPOINTS\apigp\io\Google_REST.php:66 Stack trace: #0 E:\xampp\htdocs\DATAPOINTS\apigp\io\Google_REST.php(36): Google_REST::decodeHttpResponse(Object(Google_HttpRequest)) #1 E:\xampp\htdocs\DATAPOINTS\apigp\service\Google_ServiceResource.php(186): Google_REST::execute(Object(Google_HttpRequest)) #2 E:\xampp\htdocs\DATAPOINTS\apigp\contrib\Google_AnalyticsService.php(139): Google_ServiceResource->__call('list', Array) #3 E:\xampp\htdocs\DATAPOINTS\anatest.php(33): Google_ManagementAccountsServiceResource->listManagementAccounts() #4 {main} thrown in E:\xampp\htdocs\DATAPOINTS\apigp\io\Google_REST.php on line 66

How to get analytics data without login in api ?

like image 255
Yugal Avatar asked Apr 03 '14 11:04

Yugal


People also ask

How do I log into Google Analytics without a Google account?

You can use Google Analytics without a gmail account, however you must still link your current email to Google's services. Go to https://www.google.com/accounts/NewAccount and select "use my current email address instead."

How do I access my Google Analytics API?

To get started using Analytics API, you need to first use the setup tool, which guides you through creating a project in the Google API Console, enabling the API, and creating credentials. To set up a new service account, do the following: Click Create credentials > Service account key.


1 Answers

According to Google, you must send authorization credentials with each API request.

See here: https://developers.google.com/analytics/devguides/reporting/core/v3/#user_reports

like image 78
Hani Avatar answered Oct 19 '22 14:10

Hani