簡體   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