如何解决iframe 中的 gtag 子域
我正在尝试处理 gtag.js 以跟踪页面浏览量,
它在独立页面或同一个父域内的 iframe 上工作正常,但当 iframe 父不在同一个域中时它不起作用(在 firefox 上工作,但不在 chrome/chromium 中)
-
父页面:abc.domain.com
- iframe1:def.domain.com
- gtag 页面浏览正常
- iframe2:ghi.domain.com
- gtag 页面浏览正常
- iframe1:def.domain.com
-
父页面:abc.running.com
- iframe1:def.domain.com
- gtag 页面视图不起作用
- iframe2:ghi.domain.com
- gtag 页面视图不起作用
- iframe1:def.domain.com
我控制 domain.com,我不控制 running.com,我的 iframe 只是通过外部脚本包含在其中
gtag 页面查看正常 = 我可以在网络检查器中看到收集 http 请求
gtag 页面视图不起作用 = 我在 chrome/chromium 上的网络检查器中看不到收集 http 请求,但我可以在 Firefox 上看到
包含在 iframe 中的我的 gtag javascript 代码非常简单:
<script async src="https://www.googletagmanager.com/gtag/js?id=TAGID"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js',new Date());
gtag('config','TAGID',{
page_path: "/page1",page_title: "Page 1"
});
</script>
我尝试添加 cookie_flags 字段,但它没有改变任何内容
<script async src="https://www.googletagmanager.com/gtag/js?id=TAGID"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js',page_title: "Page 1",cookie_flags: "samesite=none;domain=domain.com;secure",});
</script>
解决方法
我假设您的页面和 Iframe 都通过 HTTPS 访问并且拥有有效的 SSL 证书?这对于 SameSite/Secure 标志很重要。
我相信没有cookie_flag域,不需要设置域。
cookie_flags: "SameSite=None;Secure",
如果它不起作用,请检查(或添加屏幕截图)在 Iframe 范围内的 chrome 开发工具中的 cookie(应用程序 -> Cookies -> def.domain.com)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。