Wysyłaj zdarzenia Measurement Protocol do Google Analytics

Z tego przewodnika dowiesz się, jak wysyłać zdarzenia z Measurement Protocol do Google Analytics do strumienia danych z sieci i aplikacji, aby móc wyświetlać je w raportach Google Analytics.

Wybierz platformę, którą chcesz zobaczyć w tym przewodniku:

Formatowanie żądania

Platforma Google Analytics Measurement Protocol obsługuje tylko żądania HTTP POST.

Aby wysłać zdarzenie, użyj tego formatu:

POST /mp/collect HTTP/1.1
HOST: www.google-analytics.com
Content-Type: application/json
<payload_data>

W adresie URL żądania musisz podać te parametry:

  • api_secret: TAJNY KLUCZ API wygenerowany w interfejsie Google Analytics.

    Aby utworzyć nowy obiekt tajny, kliknij kolejno Administracja > Strumienie danych > wybierz swój strumień > Measurement Protocol > Utwórz.

  • measurement_id: identyfikator pomiaru powiązany ze strumieniem, widoczny w interfejsie Google Analytics w polu Administracja > Strumienie danych > wybierz swój strumień > Identyfikator pomiaru.

    measurement_id nie jest Twoim identyfikatorem strumienia.

Pełną listę parametrów zapytania znajdziesz w sekcji Parametry zapytania.

W treści żądania musisz podać:

  • client_id: unikalny identyfikator klienta. Różni się to od app_instance_id w Firebase. Użyj tagu gtag.js('get').
  • user_id: opcjonalna. unikalny identyfikator użytkownika. Może zawierać tylko znaki w kodowaniu UTF-8. Więcej informacji o tym identyfikatorze znajdziesz w artykule Używanie funkcji User-ID do analizy obejmującej wiele platform.

  • consent: opcjonalna. Dowiedz się, jak skonfigurować ustawienia zgody.

  • timestamp_micros: opcjonalna. czas od początku epoki uniksowej podawany w mikrosekundach w przypadku zdarzeń i właściwości użytkownika występujących w żądaniu. Jeśli nie podasz tej wartości, będzie ona domyślnie ustawiona na czas żądania.

  • events: tablica ze zdarzeniami. W jednym żądaniu możesz przesłać większą liczbę zdarzeń.

    Aby aktywność użytkownika była widoczna w raportach, np. w raporcie Czas rzeczywisty, parametry engagement_time_msecsession_id muszą być podane w ramach parametru params dla zdarzenia event. Parametr engagement_time_msec powinien odzwierciedlać czas zaangażowania dotyczący zdarzenia w milisekundach.

    Oto przykład:

  {
   "client_id": "123456.7654321",
   "events": [
     {
        "name": "campaign_details",
        "params": {
          "campaign_id": "google_1234",
          "campaign": "Summer_fun",
          "source": "google",
          "medium": "cpc",
          "term": "summer+travel",
          "content": "logolink",
          "session_id": "123",
          "engagement_time_msec": 100
        }
     }
   ]
  }

Chociaż session_start to zarezerwowana nazwa zdarzenia, utworzenie nowego parametru session_id powoduje utworzenie nowej sesji bez konieczności wysyłania parametru session_start. Dowiedz się, jak są zliczane sesje.

Wypróbuj

Oto przykład wysyłania wielu zdarzeń jednocześnie. W tym przykładzie na serwer Google Analytics wysyłane są zdarzenia tutorial_beginjoin_group.

const measurement_id = `G-XXXXXXXXXX`;
const api_secret = `<secret_value>`;

fetch(`https://www.google-analytics.com/mp/collect?measurement_id=${measurement_id}&api_secret=${api_secret}`, {
  method: "POST",
  body: JSON.stringify({
    client_id: "XXXXXXXXXX.YYYYYYYYYY",
    events: [
      {
        name: "tutorial_begin",
        params: {
          "session_id": "123",
          "engagement_time_msec": 100
        }
      },
      {
        name: "join_group",
        params: {
          "group_id": "G_12345",
          "session_id": "123",
          "engagement_time_msec": 150
        }
      }
    ]
  })
});

Zastąpiona sygnatura czasowa

W przypadku każdego zdarzenia w żądaniu Measurement Protocol używa pierwszej sygnatury czasowej z poniższej listy:

  1. timestamp_micros zdarzenia.
  2. timestamp_micros żądania.
  3. Czas, w którym Measurement Protocol odbiera żądanie.

W tym przykładzie wysyłamy sygnaturę czasową na poziomie żądania, która dotyczy wszystkich zdarzeń w żądaniu. W rezultacie Measurement Protocol przypisuje sygnaturę czasową requestUnixEpochTimeInMicros zarówno zdarzeniu tutorial_begin, jak i zdarzeniem join_group.

{
  "timestamp_micros": requestUnixEpochTimeInMicros,
  "events": [
    {
      "name": "tutorial_begin"
    },
    {
      "name": "join_group",
      "params": {
        "group_id": "G_12345",
      }
    }
  ]
}

W tym przykładzie jest wysyłana zarówno sygnatura czasowa na poziomie żądania, jak i na poziomie zdarzenia. W rezultacie Measurement Protocol przypisuje zdarzeniu tutorial_begin sygnaturę czasową tutorialBeginUnixEpochTimeInMicros, a zdarzeniu join_group – sygnaturę czasową requestUnixEpochTimeInMicros.

{
  "timestamp_micros": requestUnixEpochTimeInMicros,
  "events": [
    {
      "name": "tutorial_begin",
      "timestamp_micros": tutorialBeginUnixEpochTimeInMicros
    },
    {
      "name": "join_group",
      "params": {
        "group_id": "G_12345",
      }
    }
  ]
}

Ograniczenia

W przypadku wysyłania zdarzeń Measurement Protocol do Google Analytics obowiązują te ograniczenia:

  • W żądaniach może być maksymalnie 25 zdarzeń.
  • Zdarzenia mogą zawierać maksymalnie 25 parametrów.
  • Zdarzenia mogą obejmować maksymalnie 25 właściwości użytkownika.
  • Nazwa właściwości użytkownika może mieć maksymalnie 24 znaki.
  • Wartości właściwości użytkownika mogą się składać z maksymalnie 36 znaków.
  • Nazwy zdarzeń mogą mieć maksymalnie 40 znaków oraz zawierać tylko znaki alfanumeryczne i znaki podkreślenia. Muszą się też zaczynać literą.
  • Nazwy parametrów, w tym parametrów produktów, mogą mieć maksymalnie 40 znaków oraz zawierać tylko znaki alfanumeryczne i znaki podkreślenia. Muszą się też zaczynać literą.
  • Wartości parametrów, w tym wartości parametrów produktów, mogą mieć maksymalnie 100 znaków w przypadku standardowej usługi w Google Analytics i 500 znaków w przypadku usługi w Google Analytics 360.
  • Parametry produktu mogą zawierać maksymalnie 10 parametrów niestandardowych.
  • Treść posta musi być mniejsza niż 130 kB.
  • Zdarzenia Measurement Protocol wysyłane do Google Analytics nie wypełniają list odbiorców Google Ads z wyszukiwania w Google Ads dotyczących użytkowników aplikacji.

Dodatkowe wymagania dotyczące każdego przypadku użycia znajdziesz w sekcji typowych zastosowań.