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

标签 javascript php html yii google-analytics

很抱歉在这里问这个问题,是否有完整指南的链接或此处设置谷歌分析示例的指南?我所能看到的只是设置注册并获取跟踪代码。然后就到此结束了。我还有其他问题。

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

  2. 我可以索要有关如何获取这些 View 的示例吗?当我访问 api 站点时,我只能看到指标。没有示例格式,我是一个十足的菜鸟。场景,我有一个网站 monitoringSite.com,我想从那里请求 mysite.com 的页面 View 。我真的只想要独特的用户页面浏览量。我真的很感激有一个请求或请求代码的示例,例如,

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

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

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

谢谢。

最佳答案

就你的观点1:是的,谷歌将每个页面 View 作为页面 View 进行跟踪(故意行为?;))。但它还能够向您显示唯一访客(或新访客),这应该就是您想要的。

对于第 2 点:首先我想确保您知道,有一个 interface from google 您可以在其中查看数据,而不需要任何 API。 然后我想确保,您知道 client librariesJavaPythonPHP 都有 JavaScript ,这使得无需知道确切的 URL。然后在您验证后,您不需要库或接口(interface),我将编辑帖子。

编辑: 好的,还有一个您想要的类别:访问(它与页面浏览量不同),您可以看到它们是如何计算的 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_PATH 中。 VIEW_ID不是您的UA-XXXXX-X代码,但可以在分析界面(Admin< kbd>查看设置查看ID)和CURLOPT_SSL_VERIFYPEER应该true...试试吧与 true ,如果它不起作用..你知道......无论如何,使用谷歌并将其设置为 true 在任何实时版本中,因为它很容易受到人为攻击否则会发生中间攻击。

关于javascript - 设置 application.js 或 ga.js 或谷歌分析初学者指南?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21143006/

相关文章:

javascript - 使用 jQuery 创建一个新的 div

PHP,单选按钮返回,而不是值

php - 如何降低返回值取决于 3 个 bool 值的笛卡尔积的函数的圈复杂度?

php - php-src 中的 “zend_execute” 函数在哪里?

javascript - 在 HTML 上将多个写入同一个 ID

javascript - puppeteer 确认

javascript - mvc3 razor - url.action javascript 错误 onClick 事件

javascript - 所需文件上传进度条

javascript - 需要按多选值数组进行分组

javascript - 聚焦于 Div