이 문서는 REST API를 이용하여 카카오톡 채널 관계 확인하기 및 카카오톡 채널 고객 관리 기능을 구현하는 방법을 안내합니다.
메서드 | URL | 인증 방식 |
---|---|---|
GET |
https://kapi.kakao.com/v2/api/talk/channels |
액세스 토큰 서비스 앱 어드민 키 |
권한 | 사전 설정 | 카카오 로그인 | 동의항목 |
---|---|---|---|
필요: 동의항목 | 플랫폼 등록 카카오 로그인 활성화 동의항목 카카오톡 채널 연결 |
필요 | 필요: 카카오톡 채널 추가 상태 및 내역 |
카카오톡 채널 관계 확인하기 API가 v2 버전으로 업그레이드되었습니다. 기존 API 정보는 별도 문서에서 확인할 수 있습니다.
사용자가 서비스와 연결된 카카오톡 채널을 추가 또는 차단했을 때 알림을 받으려면 카카오톡 채널 관계 알림을 사용합니다.
현재 로그인한 사용자와 앱에 연결된 카카오톡 채널의 친구 관계를 확인합니다.
사용자 액세스 토큰(Access Token)을 헤더에 담아 GET
으로 요청합니다. 서비스 서버에서 관리자가 요청할 경우, 앱별 어드민 키(Admin Key)로 특정 사용자의 카카오톡 채널 관계를 확인할 수 있습니다. 어드민 키는 보안에 유의해야 하므로 서버에서 호출할 때만 사용해야 합니다.
특정 카카오톡 채널의 정보만 받아보려면 channel_ids
파라미터로 해당 카카오톡 채널의 프로필 ID를 지정하여 요청합니다.
요청 성공 시 응답은 서비스 앱과 연결된 카카오톡 채널과 사용자의 관계 정보를 제공합니다. 각 카카오톡 채널 정보는 사용자와 카카오톡 채널의 현재 관계, 변경 시점과 같은 자세한 정보를 포함합니다.
사용자가 [카카오톡 채널 추가 상태 및 내역] 동의항목에 동의하지 않아 에러 응답을 받았을 경우, 추가 항목 동의 받기 기능을 사용해 사용자에게 다시 동의를 요청할 수 있습니다.
이름 | 설명 | 필수 |
---|---|---|
Authorization | Authorization: Bearer ${ACCESS_TOKEN} 인증 방식, 액세스 토큰으로 인증 요청 |
O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
channel_ids | String |
사용자와의 친구 관계를 확인할 카카오톡 채널 프로필 ID 목록 쉼표로 구분된 하나의 문자열로 전달 (예: _Bxkd,_RQxl,_vxfxm , 기본값: 앱과 연결된 모든 카카오톡 채널의 프로필 ID 목록)참고: 카카오톡 채널 프로필 ID 확인 방법 |
X |
channel_id_type | String |
카카오톡 채널 ID 타입, channel_public_id 로 고정 |
X |
이름 | 설명 | 필수 |
---|---|---|
Authorization | Authorization: KakaoAK ${SERVICE_APP_ADMIN_KEY} 인증 방식, 서비스 앱 어드민 키로 인증 요청 |
O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
target_id | String |
회원번호 | O |
target_id_type | String |
사용자 ID 타입, user_id 로 고정 |
O |
channel_ids | String |
사용자와의 친구 관계를 확인할 카카오톡 채널 프로필 ID 목록 쉼표로 구분된 하나의 문자열로 전달 (예: _Bxkd,_RQxl,_vxfxm , 기본값: 앱과 연결된 모든 카카오톡 채널의 프로필 ID 목록)참고: 카카오톡 채널 프로필 ID 확인 방법 |
X |
channel_id_type | String |
카카오톡 채널 ID 타입, channel_public_id 로 고정 |
X |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
user_id | Long |
회원번호 | O |
channels | Channels[] |
카카오톡 채널 정보 | X |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
channel_uuid | String |
카카오톡 채널의 검색용 ID | O |
channel_public_id | String |
카카오톡 채널 프로필 ID | O |
relation | String |
카카오톡 채널과 사용자 관계ADDED : 카카오톡 채널이 추가된 상태 BLOCKED : 카카오톡 채널이 차단된 상태 NONE : 카카오톡 채널이 추가되거나 차단된 적 없는 상태 |
O |
created_at | Datetime |
카카오톡 채널 추가 시간, UTC* 카카오톡 채널이 추가( ADDED ) 상태인 경우만 포함 |
X |
updated_at | Datetime |
카카오톡 채널 상태 변경 시간, UTC* 카카오톡 채널이 추가( ADDED ) 또는 차단(BLOCKED )된 상태일 경우만 포함 |
X |
* UTC: 한국 시간(KST)과 9시간 차이, RFC3339: Date and Time on the Internet 참고
curl -v -G GET "https://kapi.kakao.com/v2/api/talk/channels" \
-H "Authorization: Bearer ${ACCESS_TOKEN}" \
-d "channel_ids=_frxjem,_xnrxjem,_Brxjem"
curl -v -G GET "https://kapi.kakao.com/v2/api/talk/channels" \
-H "Authorization: KakaoAK ${SERVICE_APP_ADMIN_KEY}" \
-d "target_id_type=user_id" \
-d "target_id=${USER_ID}" \
-d "channel_ids=_frxjem,_xnrxjem,_Brxjem"
HTTP/1.1 200 OK
{
"user_id": ${USER_ID},
"channels": [
{
"channel_uuid": "@테스트",
"channel_public_id": "_ZeUTxl",
"relation": "ADDED", // ADDED, BLOCKED, NONE 중 하나
"created_at": "2020-04-18T03:17:05Z", // ADDED 상태일 때만 존재
"updated_at": "2021-05-17T05:25:01Z" // ADDED, BLOCKED 상태일 때만 존재
},
...
]
}
HTTP/1.1 400 Bad Request
{
"msg": "given account is not connected to any talk user.",
"code": -501
}
메서드 | URL | 인증 방식 |
---|---|---|
GET |
https://kapi.kakao.com/v2/api/talk/channels/multi |
서비스 앱 어드민 키 |
권한 | 사전 설정 | 카카오 로그인 | 동의항목 |
---|---|---|---|
필요: 동의항목 | 플랫폼 등록 카카오 로그인 활성화 동의항목 카카오톡 채널 연결 |
필요 | 필요: 카카오톡 채널 추가 상태 및 내역 |
사용자가 서비스와 연결된 카카오톡 채널을 추가 또는 차단했을 때 알림을 받으려면 카카오톡 채널 관계 알림을 사용합니다.
앱에 연결된 카카오톡 채널과 여러 사용자의 친구 관계를 확인합니다. 전체 또는 그룹 단위의 사용자를 대상으로 특정 카카오톡 채널과의 친구 관계를 확인하는 데 사용합니다.
서비스 앱 어드민 키를 헤더에 담아 GET
으로 요청합니다. 사용자 회원번호 목록, 카카오톡 채널 프로필 ID 목록을 쿼리 파라미터로 전달해야 합니다. 한 번에 최대 200명의 사용자를 대상으로 요청 가능합니다.
요청 처리 성공 시 응답은 각 사용자의 카카오톡 채널별 친구 관계 목록을 포함합니다. 확인에 실패한 사용자의 정보는 응답에서 제외됩니다.
이름 | 설명 | 필수 |
---|---|---|
Authorization | Authorization: KakaoAK ${SERVICE_APP_ADMIN_KEY} 인증 방식, 서비스 앱 어드민 키로 인증 요청 |
O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
target_ids | String |
회원번호 목록, 쉼표로 구분된 하나의 문자열로 구성 | O |
target_id_type | String |
사용자 ID 타입, user_id 로 고정 |
O |
channel_ids | String[] |
사용자와의 친구 관계를 확인할 카카오톡 채널의 프로필 ID 목록, 쉼표로 구분된 하나의 문자열로 구성 (예: _Bxkd,_RQxl,_vxfxm , 기본값: 앱과 연결된 모든 카카오톡 채널의 프로필 ID 목록)참고: 카카오톡 채널 프로필 ID 확인 방법 |
X |
channel_id_type | String |
카카오톡 채널 ID 타입, channel_public_id 로 고정 |
X |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
- | TalkChannelsResult[] |
각 사용자의 카카오톡 채널별 친구 관계 목록 | O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
user_id | Long |
회원번호 | O |
channels | TalkChannelRelation[] |
각 카카오톡 채널과 사용자의 관계 정보 | X |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
channel_public_id | String |
카카오톡 채널 프로필 ID | O |
channel_uuid | String |
카카오톡 채널의 검색용 ID | O |
relation | String |
카카오톡 채널과 사용자 관계ADDED : 카카오톡 채널이 추가된 상태 BLOCKED : 카카오톡 채널이 차단된 상태 NONE : 카카오톡 채널이 추가되거나 차단된 적 없는 상태 |
O |
created_at | Datetime |
카카오톡 채널 추가 시간, UTC* 카카오톡 채널이 추가( ADDED ) 상태인 경우만 포함 |
X |
updated_at | Datetime |
카카오톡 채널 상태 변경 시간, UTC* 카카오톡 채널이 추가( ADDED ) 또는 차단(BLOCKED )된 상태일 경우만 포함 |
X |
* UTC: 한국 시간(KST)과 9시간 차이, RFC3339: Date and Time on the Internet 참고
curl -v -G GET "https://kapi.kakao.com/v2/api/talk/channels/multi" \
-H "Authorization: KakaoAK ${SERVICE_APP_ADMIN_KEY}" \
-d "target_id_type=user_id" \
-d "target_ids=${USER_ID_1},${USER_ID_2},${USER_ID_3}" \
--data-urlencode 'channel_ids=_frxjem,_xnrxjem,_Brxjem'
HTTP/1.1 200 OK
[
{
"user_id": ${USER_ID_1},
"channels": [
{
"channel_public_id": "_xnrxjem",
"channel_uuid": "@플러스친구",
"relation": "ADDED",
"created_at": "2022-11-09T07:08:48Z",
"updated_at": "2023-07-20T07:21:05Z"
}
]
}, {
"user_id": ${USER_ID_2},
"channels": [
{
"channel_public_id": "_xnrxjem",
"channel_uuid": "@플러스친구",
"relation": "NONE"
}
]
},
...
]
HTTP/1.1 200 OK
[
{
"user_id": ${USER_ID_1},
"channels": [
{
"channel_public_id": "_xnrxjem",
"channel_uuid": "@플러스친구",
"relation": "ADDED",
"created_at": "2022-11-09T07:08:48Z",
"updated_at": "2023-07-20T07:21:05Z"
}
]
}
]
메서드 | URL | 인증 방식 |
---|---|---|
POST |
https://kapi.kakao.com/v1/talkchannel/create/target_user_file |
REST API 키 |
권한 | 사전 설정 | 카카오 로그인 | 동의항목 |
---|---|---|---|
- | 고객 관리 API 정책 동의 | - | - |
새로운 고객 파일을 만듭니다. 새 파일 이름은 file_name
, 적용할 필터링 기준은 schema
에 각각 정의합니다. 한 번 정의한 스키마(Schema)는 수정할 수 없으니 주의합니다.
새 고객 파일을 만드는 데 성공하면 file_id
값으로 등록된 파일 ID가 반환됩니다. 파일 ID는 해당 파일에 사용자를 추가하거나 제외할 때 사용합니다.
카카오톡 채널 고객 관리 API를 이용하여 고객 파일을 등록할 경우, 반드시 지정된 스키마 규칙을 따라야 합니다.
String
)인 경우, 지원하는 키만 사용 가능Number
) 자료형만 허용이름 | 설명 | 필수 |
---|---|---|
Authorization | Authorization: KakaoAK ${REST_API_KEY} 인증 방식, REST API 키로 인증 요청 |
O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
channel_public_id | String |
카카오톡 채널 프로필 ID 참고: 카카오톡 채널 프로필 ID 확인 방법 |
O |
schema | JSON |
고객 파일에 등록되는 데이터 항목과 항목의 종류를 정의 키(Key)와 값(Value)의 JSON 자료형(Type)으로 구성키: 생년월일, 국가, 지역, 성별, 연령, 구매금액, 포인트, 가입일, 최근 구매일, 응모일 값의 자료형: String 또는 Number |
O |
file_name | String |
관리할 파일의 이름 | O |
이름 | 타입 | 설명 |
---|---|---|
file_id | Integer |
등록된 고객 파일 ID |
curl -v -X POST "https://kapi.kakao.com/v1/talkchannel/create/target_user_file" \
-H "Authorization: KakaoAK ${REST_API_KEY}" \
-H "Content-Type: application/json" \
-d '{
"channel_public_id": "_ZeUTxl",
"file_name": "vip고객리스트",
"schema":{
"생년월일":"string",
"성별":"string",
"연령":"number"
}
}'
HTTP/1.1 200 OK
Content-Type: application/json;charset=UTF-8
{
"file_id" : 437
}
메서드 | URL | 인증 방식 |
---|---|---|
GET |
https://kapi.kakao.com/v1/talkchannel/target_user_file |
REST API 키 |
권한 | 사전 설정 | 카카오 로그인 | 동의항목 |
---|---|---|---|
- | 고객 관리 API 정책 동의 | - | - |
카카오톡 채널에 등록된 고객 파일 정보들을 확인합니다. 어떤 카카오톡 채널에 등록된 파일 정보들을 알고 싶은지 channel_public_id
파라미터의 값을 명시하여 요청합니다. 요청 성공 시 해당 카카오톡 채널에 등록된 고객 파일들의 정보를 받습니다.
이름 | 설명 | 필수 |
---|---|---|
Authorization | Authorization: KakaoAK ${REST_API_KEY} 인증 방식, REST API 키로 인증 요청 |
O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
channel_public_id | String |
카카오톡 채널 프로필 ID 참고: 카카오톡 채널 프로필 ID 확인 방법 |
O |
이름 | 타입 | 설명 |
---|---|---|
empty_slot | Integer |
사용 가능한 슬롯 수 |
using_slot | Integer |
사용 중인 슬롯 수 |
results | Results[] |
카카오톡 채널에 등록된 고객 파일들의 정보 |
이름 | 타입 | 설명 |
---|---|---|
file_id | Integer |
파일 ID |
file_name | String |
파일 이름 |
status | String |
파일 상태using , deleting , failed 중 하나 |
update_at | String |
파일이 업로드 된 시간 |
schema | JSON |
파일에 등록된 데이터 항목과 항목의 종류 |
curl -v -G GET "https://kapi.kakao.com/v1/talkchannel/target_user_file" \
-H "Authorization: KakaoAK ${REST_API_KEY}" \
-d "channel_public_id=_ZeUTxl"
HTTP/1.1 200 OK
Content-Type: application/json;charset=UTF-8
{
"empty_slot":27,
"using_slot":3,
"results":[
{
"file_id":437,
"file_name": "vip고객리스트",
"status":"USING",
"update_at":"2019-02-03 13:22:33",
"schema": "{\"생년월일\":\"string\",\"성별\":\"string\",\"age\":\"number\"}"
},
...
]
}
메서드 | URL | 인증 방식 |
---|---|---|
POST |
https://kapi.kakao.com/v1/talkchannel/update/target_users |
REST API 키 |
권한 | 사전 설정 | 카카오 로그인 | 동의항목 |
---|---|---|---|
- | 고객 관리 API 정책 동의 | - | - |
고객 파일에 사용자 정보를 추가합니다. 한 번에 2,000명 이하의 고객 정보를 업로드할 수 있습니다. 각 사용자를 구분하는 값인 id
는 회원번호(user_id)와 카카오톡 전화번호 중 하나여야 하고, 지정된 타입에 맞는 값을 입력해야 합니다. 스키마의 경우, 파일마다 다르게 지정되어 있으나 예제를 참고해 JSON 배열 형식으로 값을 전달합니다.
요청 성공 시, 어떤 고객 파일에 대한 요청이었는지 알려주는 file_id
와 고객 파일에 추가 요청한 사용자 수, 실제로 추가된 사용자 수를 각각 받습니다. 추가 대상 사용자 정보가 유효하지 않거나 다음의 경우에는 고객 파일에 사용자가 추가되지 않습니다. 따라서 추가 요청 사용자 수와 실제로 추가된 사용자 수는 차이가 날 수 있습니다.
다음 내용을 확인합니다.
이름 | 설명 | 필수 |
---|---|---|
Authorization | Authorization: KakaoAK ${REST_API_KEY} 인증 방식, REST API 키로 인증 요청 |
O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
file_id | Integer |
파일 ID | O |
channel_public_id | String |
카카오톡 채널 프로필 ID 참고: 카카오톡 채널 프로필 ID 확인 방법 |
O |
user_type | String |
등록할 사용자 ID의 기준 값app (회원번호) 또는 phone (카카오톡 전화번호) 중 하나 |
O |
users | User[] |
추가할 사용자 상세 정보 목록, ID와 스키마 값 포함 | O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
id | String |
사용자 ID | O |
field | JSON |
지정된 스키마 대한 값 key, value 형태로 입력 참고: Number 또는 String 타입만 허용, String 타입인 경우 지정된 문자열만 사용 가능, 문자열은 카카오톡 채널 관리자센터 공지에 명시된 항목만 지정된 형식으로 변환해 입력 가능 |
O |
이름 | 타입 | 설명 |
---|---|---|
file_id | Integer |
파일 ID |
request_count | Integer |
고객 파일에 추가 요청한 사용자 수 |
success_count | Integer |
고객 파일에 추가된 사용자 수 |
curl -v -X POST "https://kapi.kakao.com/v1/talkchannel/update/target_users" \
-H "Authorization: KakaoAK ${REST_API_KEY}" \
-H "Content-Type: application/json" \
-d '{
"file_id": 437,
"channel_public_id": "_ZeUTxl",
"user_type": "app",
"users": [
{
"id": "12345",
"field" : {
"생년월일": "2000-01-01",
"성별": "남자",
"age": 19
}
},
...
]
}'
HTTP/1.1 200 OK
Content-Type: application/json;charset=UTF-8
{
"file_id": 437,
"request_count": 10,
"success_count": 9
}
메서드 | URL | 인증 방식 |
---|---|---|
POST |
https://kapi.kakao.com/v1/talkchannel/delete/target_users |
REST API 키 |
권한 | 사전 설정 | 카카오 로그인 | 동의항목 |
---|---|---|---|
- | 고객 관리 API 정책 동의 | - | - |
카카오톡 채널에 등록된 고객 파일에서 특정 사용자를 삭제합니다. 고객 파일에서 사용자를 삭제할 때는 성공 시에도 응답 본문이 없습니다. HTTP 상태 코드를 참고해 성공 여부를 판단합니다.
이름 | 설명 | 필수 |
---|---|---|
Authorization | Authorization: KakaoAK ${REST_API_KEY} 인증 방식, REST API 키로 인증 요청 |
O |
이름 | 타입 | 설명 | 필수 |
---|---|---|---|
file_id | Integer |
파일 ID | O |
channel_public_id | String |
카카오톡 채널 프로필 ID 참고: 카카오톡 채널 프로필 ID 확인 방법 |
O |
user_type | String |
삭제할 사용자 ID의 기준 값app (회원번호) 또는 phone (카카오톡 전화번호) 중 하나 |
O |
user_ids | JSON[] |
삭제할 사용자 ID 목록 | O |
curl -v -X POST "https://kapi.kakao.com/v1/talkchannel/delete/target_users" \
-H "Authorization: KakaoAK ${REST_API_KEY}" \
-H "Content-Type: application/json" \
-d '{
"file_id" : 437,
"channel_public_id" : "_ZeUTxl",
"user_type" : "app"
"user_ids" : ["12345"]
}'
HTTP/1.1 200 OK
Content-Length: 0
Content-Type: application/json;charset=UTF-8