搜索
清除搜索查询
关闭搜索框
Google 应用
主菜单
true

设置跨网域跟踪 (analytics.js)

通过跨网域跟踪,Google Analytics(分析)可以将两个相关网站(例如电子商务网站和单独的购物车网站)上的会话视为一个会话。这有时称为“站点关联”。

要设置跨网域跟踪,您需要能够自如地修改 HTML 并使用 JavaScript 编码,或者请经验丰富的网站开发者为您提供帮助。

详细了解如何设置基本跟踪代码。

本文包含的主题:

跨网域跟踪概览

为跟踪会话,Google Analytics(分析)收集每次匹配的 Client-ID 值。Client-ID 值存储在 Cookie 中。Cookie 存储在各个网域中,且一个网域中的网站不能访问为另一个网域设置的 Cookie。因此,在跟踪跨多个网域的会话时,需要将 Client-ID 值从一个网域传送到另一个网域。为此,Google Analytics(分析)跟踪代码具备关联功能,使源网域能够将 Client-ID 加入到链接的网址参数中,供目标网域访问。

使用 Google 跟踪代码管理器设置跨网域跟踪

如果您使用 Google 跟踪代码管理器管理 Google Analytics(分析)跟踪,请按照跨网域跟踪中的说明操作。

通过修改跟踪代码设置跨网域跟踪

要为多个顶级网域设置跨网域跟踪,您需要在每个网域上修改 Google Analytics(分析)跟踪代码。您应掌握基本的 HTML 和 JavaScript 知识或者与开发者合作才能设置跨网域跟踪。本文中的示例使用了 Universal Analytics 跟踪代码段 (analytics.js)。

  1. 在 Google Analytics(分析)帐号中设置媒体资源。
    要进行跨网域跟踪,请在 Google Analytics(分析)帐号中设置一个媒体资源。请为您的所有网域都使用来自该媒体资源的同一个跟踪代码段和跟踪 ID。

    为了让跨网域跟踪发挥作用,您需要对跟踪代码段进行修改。如果您还没有在自己的所有网页上都添加此代码段,可以先将其复制并粘贴到文本编辑器中,然后再按本文中的说明继续操作。这样一来,您只需先在文本编辑器中进行一次更改,然后再将修改后的代码段添加到您的所有网页上即可。

  2. 修改主网域的跟踪代码。
    在代码段中找到 create 行。如果网站名为 example-1.com,那么这一行会显示为:

     

      ga('create', 'UA-XXXXXXX-Y', 'example-1.com');

    对代码段进行以下更改(您需要更改的地方以红色粗体表示):

      ga('create', 'UA-XXXXXXX-Y', 'auto', {'allowLinker': true});
      ga('require', 'linker');
      ga('linker:autoLink', ['example-2.com'] );

    请记得将示例中的跟踪 ID (UA-XXXXXX-Y) 替换为您自己的跟踪 ID,并将示例中的辅助网域 (example-2.com) 替换为您自己的辅助域名。



    在您的主网域中,所有出现此跟踪代码段的地方都必须包含这些更改。

     

    三个或更多个网域

    按上例所示操作,但是要为自动链接插件再添加其他网域。请注意其中额外的逗号,这个符号非常重要:

    ga('linker:autoLink', ['example-2.com', 'example-3.com'] );
    查看完整代码段的示例

    您的主网域的跟踪代码段应如下所示:

    <script>

    (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) })(window,document,'script','//www.google-analytics.com/analytics.js','ga');

    ga('create', 'UA-XXXXXXX-Y', 'auto', {'allowLinker': true});
    ga('require', 'linker');
    ga('linker:autoLink', ['example-2.com'] );

    ga('send', 'pageview');

    </script>
  3. 修改辅助网域的跟踪代码。

    在代码段中找到 create 行。对代码段进行以下更改(您需要更改的地方以红色粗体表示):

      ga('create', 'UA-XXXXXXX-Y', 'auto', {'allowLinker': true});
      ga('require', 'linker');
      ga('linker:autoLink', ['example-1.com'] );

    请记得将示例中的跟踪 ID (UA-XXXXXX-Y) 替换为您自己的跟踪 ID,并将示例中的主网域 (example-1.com) 替换为您自己的主域名。

    在您的辅助网域中,所有出现此跟踪代码段的地方都必须包含这些更改。

    三个或更多个网域

    按上例所示操作,但是要为自动链接插件再添加其他网域。请注意其中额外的逗号,这个符号非常重要:

    ga('linker:autoLink', ['example-1.com', 'example-3.com'] );
    查看完整代码段的示例

    您的辅助网域的跟踪代码段应如下所示:

    <script>

    (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) })(window,document,'script','//www.google-analytics.com/analytics.js','ga');

    ga('create', 'UA-XXXXXXX-Y', 'auto', {'allowLinker': true});
    ga('require', 'linker');
    ga('linker:autoLink', ['example-1.com'] );

    ga('send', 'pageview');

    </script>

设置报告数据视图和添加过滤器

默认情况下,Google Analytics(分析)仅会添加网页路径和网页名称,不会添加域名。例如,您可能会在网站内容报告中看到网页如下所示:

  • /about/contactUs.html
  • /about/contactUs.html
  • /products/buy.html

由于域名不会列出,因此您可能会很难分辨每个网页所属的网域。

要让您的报告显示域名,您需要执行以下两项操作:创建报告数据视图副本(其中应包含所有网域的数据),并向该新数据视图添加高级过滤器。此过滤器会让 Google Analytics(分析)在您的报告中显示域名。

在设置跨网域跟踪后,请按照以下示例设置会在您的报告中显示域名的数据视图过滤器。对于有些字段,您需要从下拉菜单中选择一个项目。对于另外一些字段,您需要输入以下字符:

  • 过滤器类型:自定义过滤器 > 高级
  • 字段 A:主机名提取 A:(.*)
  • 字段 B:请求 URI 提取:(.*)
  • 输出至:请求 URI 构造器:$A1$B1

点击保存以创建过滤器。

可以使用 Google Tag Assistant 记录验证该过滤器的工作状态是否符合要求。Tag Assistant 记录可以准确显示过滤器对流量的改变情况。

向引荐排除列表添加网域

当用户行为历程从第一个网域转到第二个网域时,Google Analytics(分析)的解读是,第一个网域将用户引荐到了第二个网域,并且 Google Analytics(分析)会创建一个新的会话。如果您希望跨多个网域跟踪单个会话,则需要将您的网域添加到引荐排除列表

检查跨网域跟踪运行情况

要验证跨网域跟踪的设置是否正确,最好的方法是使用 Google Tag Assistant 记录。只要会话跨网域,它就可以立即显示跟踪是否正常。

以下示例 Tag Assistant 记录报告显示在跨网域跟踪设置错误时,会显示哪些内容。

相关资源

analytics.js

gtag.js

 

本文是否对您有帮助?
您有什么改进建议?