Cómo usar Tag Manager con una Política de Seguridad del Contenido

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

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

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.

  1. Abre Tag Assistant y, luego, ingresa la URL de tu sitio web. Se abrirá una nueva pestaña con tu sitio web.

  2. 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.

    Captura de pantalla de Tag Assistant que muestra un problema de CSP

  3. Selecciona Ver problema junto al problema de la CSP para ver la lista de todos los recursos bloqueados en tu página. Captura de pantalla de Tag Assistant en la que se muestra el control deslizante del problema de la CSP

  4. Agrega todos los recursos bloqueados a tu Política de Seguridad del Contenido.