이 가이드에서는 Google 애널리틱스 보고서에서 측정 프로토콜 이벤트를 확인할 수 있도록 Google 애널리틱스 측정 프로토콜 웹 및 앱 스트림 이벤트를 Google 애널리틱스 서버로 전송하는 방법을 설명합니다.
이 가이드에서 확인할 플랫폼을 선택하세요.
요청 형식 지정
Google 애널리틱스 측정 프로토콜은 HTTP POST
요청만 지원합니다.
이벤트를 전송하려면 다음 형식을 사용하세요.
POST /mp/collect HTTP/1.1
HOST: www.google-analytics.com
Content-Type: application/json
PAYLOAD_DATA
요청 URL에 다음을 포함해야 합니다.
api_secret
: Google 애널리틱스 UI에서 생성된 API 비밀번호입니다.새 비밀번호를 만들려면 관리 > 데이터 수집 및 수정 > 데이터 스트림 > 스트림 선택 > 측정 프로토콜 API 비밀번호 > 만들기로 이동합니다.
measurement_id
: 스트림과 연결된 측정 ID로, 관리자 > 데이터 스트림 > 스트림 선택 > 측정 ID 아래의 Google 애널리틱스 UI에서 찾을 수 있습니다.measurement_id
는 스트릠 ID가 아닙니다.
측정 프로토콜의 경우 JSON POST 본문 형식으로 요청 본문을 제공해야 합니다. 예를 들면 다음과 같습니다.
{
"client_id": "CLIENT_ID",
"events": [
{
"name": "login",
"params": {
"method": "Google",
"session_id": "SESSION_ID",
"engagement_time_msec": 100
}
}
]
}
session_start
는 예약된 이벤트 이름이지만 새 session_id
를 만들면 session_start
를 전송하지 않고도 새 세션을 만들 수 있습니다. 세션수를 집계하는 방법을 알아보세요.
직접 해 보기
다음은 여러 이벤트를 한 번에 전송하는 데 사용할 수 있는 예입니다. 이 예에서는 tutorial_begin
이벤트와 join_group
이벤트를 Google 애널리틱스 서버로 전송하고, user_location
필드를 사용하여 지리적 정보를 포함하고, device
필드를 사용하여 기기 정보를 포함합니다.
const measurementId = "MEASUREMENT_ID";
const apiSecret = "API_SECRET";
fetch(`https://www.google-analytics.com/mp/collect?measurement_id=${measurementId}&api_secret=${apiSecret}`, {
method: "POST",
body: JSON.stringify({
client_id: "CLIENT_ID",
events: [
{
name: "tutorial_begin",
params: {
"session_id": "SESSION_ID",
"engagement_time_msec": 100
}
},
{
name: "join_group",
params: {
"group_id": "G_12345",
"session_id": "SESSION_ID",
"engagement_time_msec": 150
}
}
],
user_location: {
city: "Mountain View",
region_id: "US-CA",
country_id: "US",
subcontinent_id: "021",
continent_id: "019"
},
device: {
category: "mobile",
language: "en",
screen_resolution: "1280x2856",
operating_system: "Android",
operating_system_version: "14",
model: "Pixel 9 Pro",
brand: "Google",
browser: "Chrome",
browser_version: "136.0.7103.60"
}
})
});
타임스탬프 재정의
측정 프로토콜은 요청의 각 이벤트에 대해 다음 목록에서 찾은 첫 번째 타임스탬프를 사용합니다.
- 이벤트의
timestamp_micros
입니다. - 요청의
timestamp_micros
로, - 측정 프로토콜이 요청을 수신한 시간입니다.
다음 예시에서는 요청의 모든 이벤트에 적용되는 요청 수준 타임스탬프를 전송합니다. 따라서 측정 프로토콜은 tutorial_begin
및 join_group
이벤트에 requestUnixEpochTimeInMicros
타임스탬프를 할당합니다.
{
"timestamp_micros": requestUnixEpochTimeInMicros,
"events": [
{
"name": "tutorial_begin"
},
{
"name": "join_group",
"params": {
"group_id": "G_12345",
}
}
]
}
다음 예에서는 요청 수준 타임스탬프와 이벤트 수준 타임스탬프를 모두 전송합니다. 따라서 측정 프로토콜은 tutorial_begin
이벤트에 tutorialBeginUnixEpochTimeInMicros
타임스탬프를 할당하고 join_group
이벤트에 requestUnixEpochTimeInMicros
타임스탬프를 할당합니다.
{
"timestamp_micros": requestUnixEpochTimeInMicros,
"events": [
{
"name": "tutorial_begin",
"timestamp_micros": tutorialBeginUnixEpochTimeInMicros
},
{
"name": "join_group",
"params": {
"group_id": "G_12345",
}
}
]
}
제한사항
Google 애널리틱스로 측정 프로토콜을 전송하는 데는 다음 제한사항이 적용됩니다.
- 요청은 최대 25개의 이벤트를 포함할 수 있습니다.
- 이벤트는 최대 25개의 매개변수를 포함할 수 있습니다.
- 이벤트는 최대 25개의 사용자 속성을 포함할 수 있습니다.
- 사용자 속성 이름은 24자(영문 기준) 이하여야 합니다.
- 사용자 속성 값은 36자(영문 기준) 이하여야 합니다.
- 이벤트 이름은 40자(영문 기준) 이하여야 하고 영숫자 및 밑줄 문자만 사용할 수 있으며 알파벳으로 시작해야 합니다.
- 항목 매개변수를 포함한 매개변수 이름은 40자(영문 기준) 이하여야 하고 영숫자 및 밑줄 문자만 사용할 수 있으며 알파벳으로 시작해야 합니다.
- 상품 매개변수 값을 포함한 매개변수 값은 표준 Google 애널리틱스 속성의 경우 100자(영문 기준) 이하여야 하고, Google 애널리틱스 360 속성의 경우 500자(영문 기준) 이하여야 합니다.
- 항목 매개변수는 최대 10개의 맞춤 매개변수를 포함할 수 있습니다.
- POST 본문은 130KB보다 작아야 합니다.
- Google 애널리틱스로 전송된 앱 측정 프로토콜 이벤트는 앱 사용자의 Google Ads 검색 잠재고객을 채우지 않습니다.
각 사용 사례의 추가 요구사항은 일반 사용 사례를 참고하세요.