设置application.js或ga.js或初学者的谷歌分析指南?

时间:2014-01-15 16:34:05

标签: javascript php html yii google-analytics

很抱歉在这里提出这个问题,是否有链接指向完整指南或指南设置示例google analytics?我所能看到的只是设置注册并对跟踪代码进行格式化。然后就在那里结束。我还有其他问题。

  1. 当在标题之前放置代码时,我读到当加载页面时,代码运行。那么将同一网站的不同页面计为不同的视图?例如,访问mysite.com,然后访问mysite.com/info,然后访问mysite.com/contacts。这会发送/创建3个不同的页面浏览量吗?我怎么才能做到只有一个?如果它是同一个用户并且只是通过不同的部分?

  2. 我可以询问如何获得这些观点的样本吗?当我访问api网站时,我只能看到指标。没有样本格式,我是一个完整的菜鸟。方案,我有一个网站monitoringSite.com,从那里我想要请求mysite.com的网页浏览量。我真的只想要独特的用户页面浏览量。我真的很感激有一个请求或请求代码的样本,如

      $this->curl('https://googleanalytics.com/idontknowwhattoputhere');
    

    对于每个请求,是否需要登录数据?

  3. 我实际上已经创建了一个帐户并获得了UA-XXXXX-X代码,我不知道接下来要做什么。我没有把ga.js放在mysite.com上,但是在我说完之后,它会自动开始发送并通过请求获取视图(如果我已经知道如何请求,那就是。)。

    谢谢。

1 个答案:

答案 0 :(得分:0)

要点1:是的谷歌跟踪每个页面视图作为页面视图(故意行为?;))。但它也可以向您显示唯一身份访问者(或新访问者),这应该是您想要的。

要点2:首先,我想确保您知道有一个interface from google,您可以在其中查看数据,无需任何API。 然后我想确保您知道client librariesJavaPythonPHPJavaScript,这样就无需了解确切内容URL。然后在验证后,您不需要库或界面,我将编辑帖子。

编辑: 好的,所以还有一个你想要的类别:访问(它与网页浏览不同),你可以看到它们的计算方式here;基本上新访问是在30分钟不活动或某些其他合理条件之后。

关于普通API的事情;这个网站应该是你想要的:https://developers.google.com/analytics/devguides/reporting/core/v3/reference

我能给你的所有信息都写在那里。

编辑2: 所以最后这是一个工作示例(当然替换了占位常量):

<?php

class GoogleAnalytics {

    // Replace those
    const MAIL = '1234567890@developer.gserviceaccount.com';
    const PRIVATE_KEY_PATH = '/home/matmarbon/path/to/your/'.
            '1234567890abcdef1234567890abcdef12345678-privatekey.p12';
    const VIEW_ID = 12345678;
    const CURLOPT_SSL_VERIFYPEER = false;// ATTENTION: THIS MIGHT BE DANGEROUS!

    // Don't replace those
    const AUTHURL = 'https://accounts.google.com/o/oauth2/token';
    const SCOPE = 'https://www.googleapis.com/auth/analytics.readonly';

    public function curl($url, $post, $params) {
        $ch = curl_init();
        if($post) {
            $query = '';
            foreach($params as $k => $v)
                $query .= $k.'='.urlencode($v).'&';
            rtrim($query, '&');
            curl_setopt_array($ch, array(
                CURLOPT_POST => count($params),
                CURLOPT_POSTFIELDS => $query
            ));
        } else if($params) {
            $url .= '?';
            foreach($params as $k => $v)
                $url .= $k.'='.urlencode($v).'&';
            rtrim($url, '&');
        }
        curl_setopt_array($ch, array(
            CURLOPT_URL => $url,
            CURLOPT_RETURNTRANSFER => 1,
            CURLOPT_SSL_VERIFYPEER => self::CURLOPT_SSL_VERIFYPEER
        ));
        $output = curl_exec($ch);
        if($output === false)
            throw new Exception('Error getting auth code: '.curl_error($ch));
        curl_close($ch);
        return $output;
    }

    public function auth($mail,$privateKeyPath,$force=false) {
        if(!$force && !empty($_SESSION['ga_auth']))
            if($_SESSION['ga_auth_time'] > time())
                return $_SESSION['ga_auth'];
        $jwt = 'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.';
        $claimset = array(
            'iss' => $mail,
            'scope' => self::SCOPE,
            'aud' => self::AUTHURL,
            'exp' => time() + 60 * 60,
            'iat' => time()
        );
        // utf8_encode ?
        $jwt .= base64_encode(json_encode($claimset));

        $c = array();
        $key = file_get_contents($privateKeyPath);
        openssl_pkcs12_read($key, $c, 'notasecret');
        $pkeyid = openssl_get_privatekey($c['pkey']);
        $sgn = '';
        openssl_sign($jwt, $sgn, $pkeyid, "sha256");
        openssl_free_key($pkeyid);
        $jwt .= '.'.base64_encode($sgn);
        $result = json_decode($this->curl(self::AUTHURL,true,array(
            'grant_type' => 'urn:ietf:params:oauth:grant-type:jwt-bearer',
            'assertion' => $jwt
        )), true);
        $_SESSION['ga_auth'] = $result['access_token'];
        $_SESSION['ga_auth_time'] = time() + $result['expires_in'];
        return $result['access_token'];
    }

    public function getVisitors() {
        $mail = self::MAIL;
        $privateKeyPath = self::PRIVATE_KEY_PATH;
        $auth = $this->auth($mail,$privateKeyPath);

        /// HAVE FUN HERE
        // Example:
        $json = $this->curl('https://www.googleapis.com/analytics/v3/data/ga',
                false,
                array(
                    'access_token' => $auth,
                    'ids' => 'ga:'.self::VIEW_ID,
                    'start-date' => '7daysAgo',
                    'end-date' => '1daysAgo',
                    'metrics' => 'ga:visits'
                ));

        return json_decode($json)->totalsForAllResults->{'ga:visits'};
    }

}
session_start();
$ga = new GoogleAnalytics();
echo $ga->getVisitors();

MAIL必须是开发人员控制台中的一个,还必须在那里生成并下载私钥 - 将其文件路径放入PRIVATE_KEY_PATHVIEW_ID 您的UA-XXXXX-X代码,但可以在分析界面中找到( Admin 查看设置 查看ID )和CURLOPT_SSL_VERIFYPEER shoud true ...只需尝试使用true,如果它不起作用..你知道...无论如何都要使用google并将其设置为true,因为它很容易受到中间人攻击。