Elige tu plataforma:
El Protocolo de medición de Google Analytics no devuelve códigos de error HTTP
, incluso si un evento está mal formado o le faltan parámetros obligatorios. Para verificar que tus eventos sean válidos, debes probarlos en el servidor de validación del Protocolo de Measurement antes de implementarlos en producción.
Después de validar que tus eventos estén estructurados correctamente, debes verificar tu implementación para asegurarte de que estás usando las claves correctas.
Puedes llamar al servidor de validación directamente o usar el Generador de eventos de Google Analytics. El Creador de eventos de Google Analytics te permite crear eventos de forma interactiva y usa el servidor de validación del Protocolo de medición para validarlos.
En esta guía, se describe cómo enviar eventos al servidor de validación del Protocolo de medición para Google Analytics 4 y cómo interpretar la respuesta.
Envía eventos para la validación
La única diferencia en la solicitud de eventos que se envía al servidor de validación del Protocolo de medición y al Protocolo de medición es la URL.
Servidor | URL |
---|---|
Protocolo de medición | /mp/collect |
Servidor de validación del Protocolo de medición | /debug/mp/collect |
Todos los demás campos de la solicitud son iguales.
Recomendamos el siguiente enfoque para la validación:
- Usa verificaciones de validación estrictas durante el desarrollo con cualquiera de las siguientes opciones:
- Valida las solicitudes con el Creador de eventos.
- Envía solicitudes al servidor de validación con
validation_behavior
establecido enENFORCE_RECOMMENDATIONS
.
- En producción, envía solicitudes sin configurar
validation_behavior
para minimizar los datos rechazados por el Protocolo de medición.
En el siguiente código, se muestra un evento no válido que se envía al servidor de validación de Measurement Protocol:
Respuesta de validación
Esta es la respuesta del servidor de validación al evento anterior:
{
"validationMessages": [
{
"fieldPath": "events",
"description": "Event at index: [0] has invalid name [_badEventName]. Names must start with an alphabetic character.",
"validationCode": "NAME_INVALID"
}
]
}
A continuación, se muestra la respuesta del servidor de validación a una solicitud sin problemas de validación:
{
"validationMessages": []
}
Respuesta
Clave | Tipo | Descripción |
---|---|---|
validationMessages |
Es un array de ValidationMessage. | Es un array de mensajes de validación. |
ValidationMessage
Clave | Tipo | Descripción |
---|---|---|
fieldPath |
string | Es la ruta de acceso al campo que no era válido. |
description |
string | Es una descripción del error. |
validationCode |
ValidationCode | Es un código de validación que corresponde al error. |
ValidationCode
Valor | Descripción |
---|---|
VALUE_INVALID |
El valor proporcionado para un fieldPath no era válido. Consulta las limitaciones.
|
VALUE_REQUIRED |
No se proporcionó un valor obligatorio para un fieldPath . |
NAME_INVALID |
El nombre proporcionado no es válido. Consulta las limitaciones. |
NAME_RESERVED |
El nombre proporcionado era uno de los nombres reservados. Consulta los nombres reservados. |
VALUE_OUT_OF_BOUNDS |
El valor proporcionado era demasiado grande. Consulta las limitaciones. |
EXCEEDED_MAX_ENTITIES |
Había demasiados parámetros en la solicitud. Consulta las limitaciones. |
NAME_DUPLICATED |
Se proporcionó el mismo nombre más de una vez en la solicitud. |