GTM nonce-aware 脚本不适用于自定义 HTML 标签的所有浏览器

问题描述

我有一个使用 SSR 的 Vue 应用程序。为了实现 Content-Security-Policy,我使用了 nonce-aware version of GTM snippet

但它并没有将 nonce 添加到所有由 gtm 注入页面的脚本(特别是自定义 HTML 标记)。我遵循了提到 here解决方案,它解决了 Safari 上的问题。但它在 ChromeFirefoxEdge 上不起作用,我仍然看到这些标签错误

enter image description here

这是我的 CSP 设置:

default-src 'self';
base-uri 'self';
block-all-mixed-content;
font-src 'self' https: https://fonts.gstatic.com data:;
img-src 'self' https: data: https://www.google-analytics.com https://ssl.gstatic.com  https://www.gstatic.com https://www.googletagmanager.com;
object-src 'none';
script-src 'self' 'nonce-b62382357618aee340fc9dc596c94a19' https://www.google-analytics.com/ https://ssl.google-analytics.com https://tagmanager.google.com https://www.googletagmanager.com 127.0.0.1:*;
script-src-attr 'none';
style-src 'self' 'unsafe-inline' https://tagmanager.google.com https://fonts.googleapis.com;
upgrade-insecure-requests;
connect-src 'self' https://www.google-analytics.com https://stats.g.doubleclick.net;

经过数小时的研究,我发现了以下评论

Chrome 屏蔽了 nonce 属性值,因此标签管理器无法获取它并将其存储为变量。

我不确定这是否真的是问题,但谁能解释一下我如何在不使用 unsafe-inline 或散列的情况下解决这个问题,因为似乎即使在 Google 文档中也没有标准的方法来修复它?

解决方法

在互联网上搜索了大量内容并阅读了不同的文章后,我发现here 提到的解决方案在 Safari 中运行良好,但在其他浏览器中运行良好,因为:

Chrome、Safari 和 Edge 屏蔽了 nonce 属性值,因此 GTM 无法获取它并将其存储为变量。

考虑到 this solution 用于将 nonce 传播到自定义 HTML 标签,我们继续应用以下更改来解决 Chrome、Firefox 和 Edge 上的此问题。 按照建议 here in the comments 我们需要稍微修改 nonce-aware 脚本并将 nonce 放在 data- 属性中(然后浏览器不会屏蔽它),并将其推送到 dataLayer:

<!-- Google Tag Manager -->
<script
  nonce='{{YOUR_GTM_NONCE}}'
  data-gtm-nonce='{{YOUR_GTM_NONCE}}'
>
  (function(w,d,s,l,i){
    const gtmNonce = d.querySelector('[data-gtm-nonce]').dataset.gtmNonce;
    w[l]=w[l]||[];
    w[l].push({'nonce': gtmNonce});
    w[l].push({'gtm.start': new Date().getTime(),event:'gtm.js'});
    const f=d.getElementsByTagName(s)[0],j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';
    j.async=true;
    j.src='https://www.googletagmanager.com/gtm.js?id='+i+dl;
    j.setAttribute('nonce',gtmNonce);
    f.parentNode.insertBefore(j,f);
  })(window,document,'script','dataLayer','YOUR_GTM_ID');
</script>
<!-- End Google Tag Manager -->

然后在 GTM 中,您需要更改您根据 this solution 从此定义的 nonce 变量: enter image description here

对此enter image description here

其余的将保持不变。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...