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.
firebase_app_id
: identyfikator aplikacji Firebase, który znajdziesz w konsoli Firebase w sekcji Ustawienia projektu > Ogólne > Twoje aplikacje > Identyfikator aplikacji.Wartość właściwości
firebase_app_id
nie może być identyczna z wartością właściwościapp_instance_id
.firebase_app_id
identyfikuje Twoją aplikację, aapp_instance_id
– pojedynczą jej instalację.
Pełną listę parametrów zapytania znajdziesz w sekcji Parametry zapytania.
W treści żądania musisz podać:
app_instance_id
: niepowtarzalny identyfikator instancji aplikacji Firebase. Różni się to odclient_id
w internecie:
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_msec
isession_id
muszą być podane w ramach parametruparams
dla zdarzeniaevent
. Parametrengagement_time_msec
powinien odzwierciedlać czas zaangażowania dotyczący zdarzenia w milisekundach.Oto przykład:
{
"app_instance_id": "12345678901234567890123456789012",
"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_begin
i join_group
.
const firebase_app_id = `1:1234567890:android:321abc456def7890`;
const api_secret = `<secret_value>`;
fetch(`https://www.google-analytics.com/mp/collect?firebase_app_id=${firebase_app_id}&api_secret=${api_secret}`, {
method: "POST",
body: JSON.stringify({
app_instance_id: 'app_instance_id',
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
}
}
]
})
});
Format firebase_app_id
zależy od platformy. W sekcji Pliki i obiekty konfiguracji Firebase sprawdź Application ID.
Zastąpiona sygnatura czasowa
W przypadku każdego zdarzenia w żądaniu Measurement Protocol używa pierwszej sygnatury czasowej z poniższej listy:
timestamp_micros
zdarzenia.timestamp_micros
żądania.- 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ń.