La Política de Seguridad del Contenido (CSP) es un estándar de seguridad web ampliamente compatible que tiene como objetivo evitar ciertos tipos de ataques basados en inyecciones, ya que les brinda a los desarrolladores control sobre los recursos que cargan sus aplicaciones. Usa esta guía para comprender cómo implementar Google Tag Manager en sitios que usan una CSP.
Habilita la etiqueta del contenedor para que use la CSP
Para usar Google Tag Manager en una página con una CSP, esta debe permitir la ejecución del código de tu contenedor de Tag Manager. Este código se compila como código JavaScript intercalado que inserta la secuencia de comandos gtm.js
. Existen varias formas de hacerlo, como usar un nonce o un hash. El método recomendado es usar un nonce, que debe ser un valor aleatorio e impredecible que el servidor genera de forma individual para cada respuesta. Proporciona el valor de nonce en la directiva script-src
de Content-Security-Policy:
Content-Security-Policy:
script-src 'nonce-{SERVER-GENERATED-NONCE}';
img-src www.googletagmanager.com;
connect-src www.googletagmanager.com www.google.com
Luego, usa la versión del código del contenedor de Tag Manager intercalado que reconoce el nonce. Establece el atributo nonce en el elemento de secuencia de comandos intercalada con este mismo valor:
<!-- Google Tag Manager -->
<script nonce='{SERVER-GENERATED-NONCE}'>(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start':
new Date().getTime(),event:'gtm.js'});var 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;var n=d.querySelector('[nonce]');
n&&j.setAttribute('nonce',n.nonce||n.getAttribute('nonce'));f.parentNode.insertBefore(j,f);
})(window,document,'script','dataLayer','GTM-XXXXXX');</script>
<!-- End Google Tag Manager -->
Luego, Tag Manager propagará el nonce a cualquier secuencia de comandos que agregue a la página.
Existen otros enfoques para habilitar la ejecución de una secuencia de comandos intercalada, como proporcionar el hash de la secuencia de comandos intercalada en la CSP.
Si los enfoques recomendados de nonce o hash no son factibles, es posible habilitar la secuencia de comandos intercalada de Tag Manager agregando la directiva 'unsafe-inline'
a la sección script-src
de la CSP.
Se necesitan las siguientes directivas en la CSP para usar este enfoque:
Directiva | Contenido |
---|---|
script-src | "unsafe-inline" https://www.googletagmanager.com |
img-src | www.googletagmanager.com |
connect-src | www.googletagmanager.com www.google.com |
Variables de JavaScript personalizadas
Debido a la forma en que se implementan las variables de JavaScript personalizadas, se evaluarán como undefined
en presencia de una CSP, a menos que se proporcione la directiva 'unsafe-eval'
en la sección script-src
de la CSP.
Directiva | Contenido |
---|---|
script-src | "unsafe-eval" |
Modo de vista previa
Para usar el Modo de vista previa de Google Tag Manager, la CSP debe incluir las siguientes directivas:
Directiva | Contenido |
---|---|
script-src | https://googletagmanager.com https://tagmanager.google.com |
style-src | https://googletagmanager.com https://tagmanager.google.com https://fonts.googleapis.com |
img-src | https://googletagmanager.com https://ssl.gstatic.com https://www.gstatic.com |
font-src | Datos de https://fonts.gstatic.com: |
Google Analytics 4 (Google Analytics)
Para usar la etiqueta de Google Analytics 4 (Google Analytics), la CSP debe incluir las siguientes directivas:
Directiva | Contenido |
---|---|
script-src | https://*.googletagmanager.com |
img-src | https://*.google-analytics.com https://*.googletagmanager.com |
connect-src | https://*.google-analytics.com https://*.analytics.google.com https://*.googletagmanager.com |
En el caso de las implementaciones de Google Analytics 4 (Google Analytics) que utilizan los indicadores de Google, la CSP debe incluir las siguientes directivas:
Directiva | Contenido |
---|---|
script-src | https://*.googletagmanager.com |
img-src | https://*.google-analytics.com https://*.googletagmanager.com https://*.g.doubleclick.net https://*.google.com https://*.google.<TLD> |
connect-src | https://*.google-analytics.com https://*.googletagmanager.com https://*.g.doubleclick.net https://*.google.com https://*.google.<TLD> https://pagead2.googlesyndication.com |
frame-src | https://td.doubleclick.net https://www.googletagmanager.com |
Google Ads
Para usar una etiqueta de conversión, remarketing o vinculación de conversiones de Google Ads, el CSP debe incluir las siguientes directivas:
Directiva | Contenido |
---|---|
script-src | https://www.googleadservices.com https://www.google.com https://www.googletagmanager.com https://pagead2.googlesyndication.com https://googleads.g.doubleclick.net |
img-src | https://www.googletagmanager.com https://googleads.g.doubleclick.net https://www.google.com https://pagead2.googlesyndication.com https://www.googleadservices.com https://google.com https://www.google.com.<TLD> |
frame-src | https://www.googletagmanager.com https://td.doubleclick.net |
connect-src | https://pagead2.googlesyndication.com https://www.googleadservices.com https://www.google.com https://google.com |
Baliza de datos del usuario de Google Ads
Para usar los balizas de datos del usuario de Google Ads cuando se ejecutan en contextos seguros, la CSP debe incluir las siguientes directivas:
Directiva | Contenido |
---|---|
script-src | https://www.googletagmanager.com |
frame-src | https://www.googletagmanager.com |
connect-src | https://google.com https://www.google.com |
El beacon de datos del usuario de Google Ads no se ejecuta en contextos no seguros, por lo que la configuración de la CSP en esos casos no es aplicable.
Floodlight
Los usuarios de Floodlight pueden habilitar los CSP con los siguientes parámetros de configuración. Reemplaza los valores de <FLOODLIGHT-CONFIG-ID>
por un ID de anunciante de Floodlight específico o por *
para permitir cualquier ID de anunciante:
Para todos los usuarios:
Directiva | Contenido |
---|---|
img-src | https://ad.doubleclick.net https://ade.googlesyndication.com https://adservice.google.com https://www.googletagmanager.com |
frame-src | https://td.doubleclick.net https://www.googletagmanager.com |
connect-src | https://pagead2.googlesyndication.com https://www.google.com https://www.googleadservices.com https://ad.doubleclick.net |
Para los balizas de "secuencias de comandos personalizadas", haz lo siguiente:
Directiva | Contenido |
---|---|
frame-src | https://<FLOODLIGHT-CONFIG-ID>.fls.doubleclick.net |
En el caso de las etiquetas de imagen, haz lo siguiente:
Directiva | Contenido |
---|---|
img-src | https://ad.doubleclick.net https://ade.googlesyndication.com |
Service worker
Para usar el Service Worker para la correlación mejorada, los balizas de datos del usuario y las conversiones de Google Ads, la CSP debe incluir las siguientes directivas:
Directiva | Contenido |
---|---|
frame-src | https://www.googletagmanager.com |
Cómo solucionar problemas con Tag Assistant
Para solucionar problemas relacionados con la Política de Seguridad del Contenido (CSP), usa Tag Assistant. Tag Assistant mostrará la lista de recursos que bloquea tu Política de Seguridad del Contenido.
Abre Tag Assistant y, luego, ingresa la URL de tu sitio web. Se abrirá una nueva pestaña con tu sitio web.
Si la Política de Seguridad del Contenido de tu página bloquea un recurso, se mostrará un problema de CSP en la sección Problemas de la página de Tag Assistant.
Selecciona Ver problema junto al problema de la CSP para ver la lista de todos los recursos bloqueados en tu página.
Agrega todos los recursos bloqueados a tu Política de Seguridad del Contenido.