javascript - 将文件下载事件从服务器发送到 Google Analytics

标签 javascript php apache google-analytics analytics.js

<分区>

非常相关且有帮助:Send event to Google Analytics using API server sided


下载链接通过电子邮件发送给客户:

Hello,
Please find your product here: https://www.example.com/files/yourfile.zip

我想在 Google Analytics 中跟踪此下载,作为 Goal转换。

不幸的是,当用户点击链接时,文件直接由网络服务器传送,而不是通过 .html 页面。

如何在 Analytics 中跟踪此类直接文件下载?

  1. 我是否应该在“中间”添加一个虚拟 HTML 页面,它会使用 analytics.js跟踪代码段并使用 ga.send(...) 向 GA 发送下载事件,然后在 500 毫秒后使用 setTimeout(redirect, 500) 重定向到实际文件?它真的是一个干净安全的解决方案吗?我看到许多潜在的小问题:500 毫秒可以吗?应该使用什么样的重定向?此外,禁用 JS 的用户将永远不会获得他的文件......或者如果使用 <noscript>无法记录目标转换。

  2. 有没有办法让 Apache(为客户端提供 yourfile.zip)或 PHP 在提供此文件时向 GoogleAnalytics 发送跟踪事件?

  3. 另一种解决方案?

似乎解决方案 2. 具有 100% 可靠的优势,无论客户端是否启用 JS。

但另一方面,我不想使用很少用过的 hack。对于这种非常常见的情况,通常的解决方案是什么?

最佳答案

Google Analytics 实际上有一个用于从任意来源发送分析数据的协议(protocol)。看这里:https://developers.google.com/analytics/devguides/collection/protocol/v1/

因此,让您的网络服务器向 Google 发送分析事件并不像看起来那么麻烦。我不确定您是否可以直接连接到 Apache 以生成这些事件。但是,我确实看到了至少两个解决方案。

1) 将所有下载重定向到发送数据并可以生成所需分析事件的服务器端脚本。
2) 解析服务器日志并从中生成分析事件。

解决方案 1 的编辑示例:
请确保标签前后没有空格,因为这将是发送给客户端的实际响应的一部分。

下载.php:

<?php
    // Read ?file=xxx URL parameter
    $requestedFile = $_GET["file"];

    // Read Google Analytics cookie
    $rawCookie = $_COOKIE["_ga"];
    $splitCookie = explode('.', $rawCookie);
    $trackingId = $splitCookie[2] . '.' . $splitCookie[3];

    // Create Google Analytics request data (see here https://developers.google.com/analytics/devguides/collection/protocol/v1/devguide)
    $data = array('v' => 1, 
                  'tid' => 'UA-XXXXX-Y', 
                  'cid' => $trackingId, 
                  't' => 'event', 
                  'ec' => 'download', 
                  'ea' => 'download', 
                  'el' => $requestedFile);

    // Create the request options
    $options = array(
        'http' => array(
            'method' => 'POST',
            'content' => http_build_query($data)
        )
    );

    $context = stream_context_create($options);

    // Send GA request
    $result = file_get_contents('https://www.google-analytics.com/collect', false, $context);

    // GA request failed
    if($result === FALSE) { /* Error */ }

    // Requested file does not exist
    if(!file_exists($requestedFile)) { /* Error */ }

    // Set response headers for binary data
    header('Content-Type: application/octet-stream');
    header('Content-Length: ' . filesize($requestedFile));

    // Open the requested file
    $fileHandle = fopen($requestedFile, 'r');

    // Write the requested file to stdout (which is what the client receives)
    print fread($fileHandle, filesize($requestedFile));
    flush();

    // Close the requested file again
    fclose($fileHandle);

    exit;
?>

.htaccess/mod_rewrite 规则:

RewriteEngine on
RewriteUrl ^/download/(.*)$ download.php?file=$1 [L]

自从我编写上一个 PHP 代码以来已经很久了而且我没有测试它。但它应该很好地说明如何实现选项 1)

编辑 2:如果您将跟踪请求发送到 www.google-analytics.com/debug/collect,您将收到一些验证信息,告诉您您的请求是否有效(但它不会跟踪事件)。

编辑 3: 好的,所以我检查了一个使用 analytics.js 的页面。该脚本设置以下 cookie:

_ga=GA1.3.1788966449.1501761573
_gid=GA1.3.1010429060.1501761573

稍后在它设置的收集请求中

cid:1788966449.1501761573
_gid:1010429060.1501761573

因此,您似乎需要根据在 _ga cookie 中找到的内容进行一些字符串拆分。 (我已经更新了上面的代码)

编辑 4:如果有人想知道,这是 analytics.js 脚本使用上述 cookie 值生成的请求。

GET https://www.google-analytics.com/collect?v=1&_v=j56&a=1178408574&t=pageview&_s=1&dl=https%3A%2F%2Fdevelopers.google.com%2Fanalytics%2Fdevguides%2Fcollection%2Fanalyticsjs%2Fcommand-queue-reference&ul=de&de=UTF-8&dt=The%20ga%20Command%20Queue%20Reference%20%C2%A0%7C%C2%A0%20Analytics%20for%20Web%20(analytics.js)%20%C2%A0%7C%C2%A0%20Google%20Developers&sd=24-bit&sr=1920x1200&vp=1899x1072&je=0&_u=QDCAAAIhI~&jid=&gjid=&cid=1788966449.1501761573&tid=UA-41425441-2&_gid=1010429060.1501761573&z=1116872044

关于javascript - 将文件下载事件从服务器发送到 Google Analytics,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45479302/

相关文章:

javascript - Scala函数什么时候执行

php - 关闭和打开 php 标签

php - 在类中嵌套 PHP SQL 查询

JavaScript .replace 只替换第一个匹配项

javascript - 使用 fromCharCode 的 HTML 换行符不起作用

javascript - 带有 "Responsive Width"、 "Fixed Height"、 "Center Aligned"和 "Auto Rotate"的图像 slider

php - PHRETS GetObject() 返回数组,需要提取 URL

apache 无缓存,过期

php - 模拟没有可用磁盘空间情况的最简单方法?

django - Apache 2 :/etc/apache2/sites-available is missing on macos