繁体   English   中英

设置application.js或ga.js或Google Analytics(分析)初学者指南?

[英]Setup application.js or ga.js or beginner's guide to 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'); 

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

我实际上已经创建了一个帐户,并获得了UA-XXXXX-X代码,我不知道下一步该怎么做。 我没有将ga.js东西放到mysite.com ,但是在我把它放进去之后,它将自动开始发送并可以通过请求获取视图(如果我已经知道如何请求的话)。

谢谢。

到您的观点1:是的,google会将每个网页浏览都作为网页浏览进行跟踪(故意行为?;))。 但是它也可以向您显示唯一身份访问者 (或新访问者 ),这正是您想要的。

要点2:首先,我想确保您知道Google提供了一个界面 ,您可以在其中查看数据,而无需任何API。 然后,我想确定一下,您知道有JavaPythonPHPJavaScript的 客户端库 ,因此无需知道确切的URL。 然后,在验证之后,您不需要库或接口,我将编辑帖子。

编辑:好的,所以您想要的还有一个类别: 访问 (它不同于综合浏览量 ),您可以看到,它们的计算方式在这里 基本上,新的访问是在闲置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必须是开发者控制台中的MAIL ,还必须在其中生成并下载私钥-将其文件路径放入PRIVATE_KEY_PATH VIEW_ID 不是您的UA-XXXXX-X代码,但可以在分析界面(“ 管理员 视图”设置“ 视图ID” )中找到,并且CURLOPT_SSL_VERIFYPEER 应该true …请尝试使用true ,如果它不起作用。 ...使用google并在任何实时版本中将其设置为true ,因为否则它很容易受到中间人攻击。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM