당신은 주제를 찾고 있습니까 “플러스 친구 챗봇 – 카카오톡 챗봇 만들기 -1.사전준비“? 다음 카테고리의 웹사이트 ppa.maxfit.vn 에서 귀하의 모든 질문에 답변해 드립니다: https://ppa.maxfit.vn/blog/. 바로 아래에서 답을 찾을 수 있습니다. 작성자 날먹코딩 이(가) 작성한 기사에는 조회수 4,532회 및 좋아요 36개 개의 좋아요가 있습니다.
플러스 친구 챗봇 주제에 대한 동영상 보기
여기에서 이 주제에 대한 비디오를 시청하십시오. 주의 깊게 살펴보고 읽고 있는 내용에 대한 피드백을 제공하세요!
d여기에서 카카오톡 챗봇 만들기 -1.사전준비 – 플러스 친구 챗봇 주제에 대한 세부정보를 참조하세요
카카오톡 플러스친구와 오픈빌더를 이용해 챗봇을 만드는 강의영상입니다.
/*. 영상에 오류가 있어 설명드립니다. */
1:24 화면에서 좌측 메뉴 중 프로필 → 프로필 설정 클릭 후
옵션 설정 에서 채널공개와 검색 허용을 눌러주세요.
채널공개를 안하면 오픈빌더 신청 시 URL이 검색되지 않아 반려됩니다.. ㅠㅠ
플러스 친구 챗봇 주제에 대한 자세한 내용은 여기를 참조하세요.
[ 카카오 i 오픈빌더 ] 플러스 친구 “챗봇” 만들기 – 네이버 블로그
하지만, 카카오 플러스 친구의 챗봇을 만들려면 선택권은 없습니다. 혹은 자연어 처리는 다이얼로그플로우로 처리하는 방법도 있습니다.
Source: m.blog.naver.com
Date Published: 2/2/2021
View: 8870
주요 기능 사용법 · 도움말 – 챗봇 관리자센터 – Kakao
시나리오는 봇 생성 후 메인화면에서 플러스(+) 버튼을 클릭할 때 마다 시나리오1, … 사용자가 챗봇과 친구가 아니지만, 채팅하기로 바로 대화방에 진입한 경우.
Source: i.kakao.com
Date Published: 10/22/2022
View: 3793
plusfriend/auto_reply: 플러스친구 자동응답 API – GitHub
카카오 i 오픈빌더를 통한 챗봇 제작 관련 문의는 kakao i developers DevTak에 해주시면 감사하겠습니다. [공지] 2019년 12월 31일 API형 스마트채팅 서비스가 종료 …
Source: github.com
Date Published: 10/8/2022
View: 1162
Python으로 카카오톡 플러스친구 챗봇 시작하기 – Medium
온 국민이 사용하고 있는 카카오톡!. “Python으로 카카오톡 플러스친구 챗봇 시작하기” is published by Yeonho Park in BotHub.Studio (ko).
Source: medium.com
Date Published: 1/24/2021
View: 8082
카카오톡 플러스 친구 챗봇 1:1 코칭 해드립니다. – 오투잡
카카오톡 플러스친구 챗봇 만들기 1:1 코칭시스템”을 이런 분 들께 추천 드립니다.*. – 카카오톡을 활용하여 마케팅을 하시는 분. – 코딩을 할 줄 모르시는 분.
Source: m.otwojob.com
Date Published: 8/27/2022
View: 2587
Node.js 카카오톡 플러스 친구 챗봇 만들기(1) – 가입 – velog
이번 포스팅에서는카카오톡 플러스 친구 자동응답 API를 만들어 챗봇을 만들어 보겠습니다.먼저 시작하기 전에 서비스 진행이 어떤식으로 진행되는지 …
Source: velog.io
Date Published: 12/27/2022
View: 5357
음악추천챗봇1. 카카오챗봇 설정 | 카카오 i 오픈빌더 API 이해
카카오 i 오픈빌더? 카카오톡 채널(플러스친구) 프리미어리그봇으로. 해당 플러스친구에서 채팅 화면에서 특정 메시지를 입력하면 메시지를 분석해 특정 …
Source: pearlluck.tistory.com
Date Published: 6/30/2022
View: 5794
전문 카카오톡 플러스친구 스토리 챗봇 제작해 드립니다. – 크몽
28개 총 작업 개수 완료한 총 평점 4.9점인 스낵컬쳐의 IT·프로그래밍, 챗봇 서비스를 14개의 리뷰와 함께 … 카카오톡 플러스 친구 챗봇(자동응답)만 진행합니다.
Source: kmong.com
Date Published: 3/3/2022
View: 4684
주제와 관련된 이미지 플러스 친구 챗봇
주제와 관련된 더 많은 사진을 참조하십시오 카카오톡 챗봇 만들기 -1.사전준비. 댓글에서 더 많은 관련 이미지를 보거나 필요한 경우 더 많은 관련 기사를 볼 수 있습니다.
주제에 대한 기사 평가 플러스 친구 챗봇
- Author: 날먹코딩
- Views: 조회수 4,532회
- Likes: 좋아요 36개
- Date Published: 2021. 6. 26.
- Video Url link: https://www.youtube.com/watch?v=bfE5VHX_pNA
[ 카카오 i 오픈빌더 ] 플러스 친구 “챗봇” 만들기 – 02 챗봇 만들기 시작하기
먼저 데이터를 만드는 것이 중요합니다. 혹시라도 이전에 카카오 플러스친구로 상담을 했다면, 이전의 상담 내용을 기준으로 질문과 답변 을 만들어 봅니다. 전화로 처리했다면, 이 경우에 기록이 없다면 기억에만 의존할 수 밖에 없고, 데이터를 모으기 힘들게 됩니다. 가능하다면 앞으로 전화 통화 내역도 녹음하고, 해당 내용을 텍스트로 변화해서 데이터 화 해야 합니다. 구글 STT 를 사용하면 쉽게 기본 데이터를 구축할 수 있을 겁니다.
데이터를 모으는 일 자체를 챗봇을 만들면서 하겠디만, 어쨌든 그 내용을 받고, 해당 내용에 대해서 업데이트가 필요하며, 데이터가 있다고 해도 마찬가지 입니다. 다만 처음부터 좀 더 답변 성공율이 높은 챗봇이냐 아니냐? 에 대한 것이고, 처음부터 제대로 된 답변을 하기는 어렵습니다.
어느 정도 기본적인 대화 주제와 대화 set (시나리오 등) 이 텍스트등으로 만들어졌다면,
이를 시각화 해 봅니다. 저의 경우에는 대체로 mindmap 의 형태로 정리합니다. 이 경우에 대화의 뎁스가 없다면 구지 mindmap 등으로 시각화할 필요 없이, 엑셀 혹은 구글 스프레드시트로 정리합니다.
제가 챗봇 작업 할 때의 문서 형식은 수업을 하면서 만들어 보고 있습니다.
챗봇을 만들기 전에 먼저 어떤 주제의 챗봇이고, 누가 사용하며, 누가 사용자에게 이야기 하는가? 에 대한 명확한 정리 없이 시작하면, 대화를 구성할 수도 없고, 만들 내용도 없게 됩니다. 주제만 있고 다른 내용이 없어도 마찬가지 입니다. 먼저 준비 작업을 시작해 보세요.
문서를 작성할 때는 일반적인 챗봇 제작 흐름에 맞쳐야 하며, 챗봇 제작에 대해서 전반적으로 알고 있어야 합니다. 저는 이미 여러번 시행착오를 거쳐서 작업 흐름에 맞도록 만들고 있습니다.
주요 기능 사용법 · 도움말
내가 만든 봇의 얼굴이 될 ‘카카오톡 채널’과 봇을 만드는 도구인 ‘챗봇 관리자센터’만 있으면 모든 준비 끝!
본 메뉴에서는 앞서 시작하기의 주요 개념에 이어, 실제 봇을 만들 때 필요한 각각의 메뉴 사용법을 안내합니다. 천리길도 한걸음부터, 조금씩 따라하다보면 어느새 AI챗봇 만들기에 익숙해진 내 자신을 발견합니다.
엔티티와 패턴발화, 블록, 그리고 컨텍스트까지. 이제 더 이상 어렵지 않습니다!
새로운 봇 만들기
챗봇 관리자센터에서는 간단하게 봇 이름만 입력하여 챗봇과 보이스봇을 만들 수 있습니다. 챗봇을 생성하는 과정은 아래와 같습니다.
Step 1. 로그인 후 아래 화면과 같이 비어있는 ‘나의 봇’ 목록 확인합니다.
비어 있는 봇 목록화면입니다. 가운데 파란 ‘+ 봇 만들기’ 버튼이 봇 생성버튼입니다.
Step 2. 우측 상단의 봇 만들기 버튼을 누르고, 카카오톡 챗봇을 선택합니다.
카카오톡 챗봇과 보이스봇(Closed Beta Test) 선택 팝업
Step 3. 봇 이름을 적고 확인을 누르면 생성이 완료되고 제작 페이지로 이동하게 됩니다.
카카오톡 챗봇의 이름을 입력하는 팝업
시나리오와 블록 만들기
시나리오 설정하기
봇 생성후 가장 먼저 해야할 일은 시나리오를 구성하는 것입니다. 블록을 구분하여 담아낼 수 있도록 계획을 세우고, 시나리오에 공통적으로 적용될 기능을 설정합니다. 시나리오 설정 메뉴는 다음 화면처럼 시나리오 메인 메뉴 아래 톱니바퀴 모양의 설정 아이콘으로 표시되어 있습니다.
시나리오 설정 메뉴 위치
시나리오 설정 메뉴안에서 봇 작업자는 봇에서 만든 모든 시나리오에 공통적으로 적용할 수 있는 시나리오 속성, 즉 1) 봇의 되묻기 기능에 대한 기본 설정과 2) 챗봇 사용자를 위한 봇 제네릭 메뉴를 설정할 수 있습니다.
되묻기 기능 공통 설정
시나리오 설정 메뉴안에 있는 되묻기 기능 설정 화면
위와 같이 하나의 봇 안에서 쓰이는 모든 시나리오에 공통적으로 적용될 되묻기 기능에 대하여,
되묻기 최대 횟수
되묻기 최대 시간
를 간단하게 선택하고, 각각의 경우에 대하여 유효 조건을 초과할 때 출력될 안내 메시지를 임의로 작성할 수 있습니다. (필수로 작성되어야하는 영역입니다.)
제네릭 메뉴를 추가하고 싶으면 ‘버튼 추가’를 누르면 되며, 버튼 설정은 ‘버튼 설정’을 통해 할 수 있습니다.
봇 제네릭 메뉴 내 버튼에 대한 사용자 설정 화면
버튼 설정에서는 버튼명과 버튼 기능을 직접 지정할 수 있습니다.
“퀵서비스 메뉴#1” 로 버튼명을 지정했습니다.
“퀵서비스 메뉴#2” 로 버튼명을 지정했습니다.
이때,
버튼명은 14자로 제한됩니다.
버튼 기능은 블록 연결 및 메세지 전송 두 가지만 제공됩니다.
블록 연결은 해당 버튼 클릭 시 원하는 블록으로 연결하는 것이며, 메시지 전송은 버튼을 클릭할 때 봇에게 해당 버튼명을 그대로 전송하는 것을 의미합니다.
봇 제네릭 메뉴안의 필요한 내용을 모두 작성하고, 확인 버튼을 누르면 작업 내용들이 저장됩니다.
봇 제네릭 메뉴가 설정 완료된 모습입니다
위의 예시에서 작성된 제네릭 메뉴가 카카오톡 채널 챗봇 화면에서 보여지는 모습은 아래와 같습니다.
카카오톡 채널 챗봇 하단에 사용자가 직접 클릭할 수 있는 버튼 두 개가 제네릭 메뉴 안에 구현되어있는 모습입니다.
제네릭 메뉴안의 각 버튼은 기존에 작성된 블록으로 연결될 수 있고, 사용자가 버튼을 누르면 제네릭 메뉴 안의 버튼명이 그대로 출력되고 해당 블록의 출력으로 설정된 말풍선이 나타납니다.
시나리오 생성하기
이제 시나리오를 생성해보겠습니다. 시나리오는 봇 생성 후 메인화면에서 플러스(+) 버튼을 클릭할 때 마다 시나리오1, 시나리오2… 순으로 생성됩니다.
시나리오 추가 기능 위치
시나리오의 이름 또한 손쉽게 수정할 수 있으며, 필요하면 삭제도 가능합니다.
시나리오명칭 우측에 있는 ‘더보기’ 아이콘 클릭 후 ‘편집’을 클릭하면 이름 수정이 가능합니다
시나리오 명칭 변경 모습
시나리오 명칭 우측에 있는 ‘더보기’ 아이콘 클릭 후 ‘삭제’를 클릭하면 해당 시나리오가 삭제 됩니다.
봇 작업자는 하나의 시나리오 안에는 사용자 의도를 나타내는 ‘블록’들을 [+ 블록추가] 버튼을 눌러 여러개 작성할 수 있습니다.
시나리오 안에서 블록 만들기
시나리오를 선택하면 기본적으로 우측 화면에 블록의 내용을 바로 채울 수 있는 화면을 볼 수 있습니다. 봇 작업자는 해당 화면의 위에서부터, 사용자 발화 패턴 설정 → 봇 응답형식 설정 순으로 필요 내용을 작성할 수 있습니다.
이때 파라미터 설정 부분은 메뉴가 접혀있습니다. 봇 작업자가 필요에 따라 챗봇 관리자센터의 스킬이나 플러그인 기능을 이용해야 한다면, 해당 파라미터 설정 부분을 클릭하여 메뉴를 펼치고 필요한 내용을 채우면 됩니다.
블록 만들기 디폴트 화면
참고로, 하나의 봇 안에서 시나리오가 점차 많아지게 되면, 봇 작업자는 특정 시나리오 및 블록들의 콘텐츠 유지보수를 할 때 정확한 위치를 찾기가 어려워질 수 있습니다. 그럴때는 시나리오 메인 메뉴에 있는 검색 창에서 검색 희망 키워드를 입력하면, 그에 해당하는 시나리오 및 블록들이 즉시 하이라이트 되어 나타납니다. 이를 통해 봇 작업자는 필요 업데이트 작업을 빠르게 진행할 수 있습니다.
키워드 검색에 따라 시나리오명이 하이라이트 된 모습
키워드 검색에 따라 블록명이 하이라이트 된 모습
시나리오간 블록 이동하기
봇 작업자는 시나리오안에서 작성된 블록을 타 시나리오로 직접 이동시킬수 있습니다. ‘블록 이동’ 개념이므로, 사본이 생성되어 이동되는 것은 아님을 유의하여 주십시오.
타 시나리오로의 이동이 필요한 블록을 선택하시고, 우측의 ‘더보기’ 버튼을 클릭하면, ‘이동’ 메뉴가 나타납니다. 그리고, ‘이동’ 메뉴를 클릭합니다.
블록이동을 위한 안내 팝업을 확인하고, 블록을 이동시킬 시나리오명을 선택해줍니다.
대상 블록이 기존 ‘시나리오01’에서, 새로운 ‘시나리오02’라는 지점으로 이동한 것을 알 수 있습니다.
기본 블록 설정하기
주요 개념 > 블록에서 설명한 것처럼, 챗봇 관리자센터가 봇을 생성 후 기본적으로 항시 제공하는 블록들을 기본 블록이라고 합니다.
기본 블록은 웰컴 블록, 폴백 블록, 탈출 블록 총 세 가지로 구성되어 있으며, 각 블록을 설정하는 방법은 다음의 그림을 참고해주시길 바랍니다.
작업자는 봇을 생성하고 나면 메인화면 좌측에서 기본 블록에 바로 접근할 수 있습니다.
봇 작업자가 봇을 생성하고 나면, 기본 블록은 기본 시나리오 메뉴 하단에 디폴트로 위치하게 됩니다. 봇 작업자는 봇을 만드는 중에 언제든 접근해서 필요한 세팅을 할 수 있습니다
웰컴 블록(Welcome Block) 설정하기
웰컴 블록은 봇 사용자가 봇을 처음 사용할 때 받게되는 응답을 설정하는 블록입니다.
웰컴 블록 내 메시지 꾸미기를 위한 말풍선 선택화면
봇 응답 형식 설정 우측에 있는 + 버튼을 클릭하면, 봇이 발송하는 웰컴 메시지를 어떤 말풍선에 담아서 꾸밀 것인지를 선택할 수 있습니다. 텍스트형, 이미지형, 카드형, 커머스형, 리스트형 또는 스킬을 연결하는 등 다양한선 타입을 골라 메시지를 채울 수 있습니다. 단, 웰컴 블록의 담긴 메시지는 카카오톡 채널 챗봇을 이용하는 사용자의 경우
사용자가 카카오톡 채널을 봇과 연결한 다음 처음으로 대화방에 진입한 경우
사용자가 챗봇과 친구가 아니지만, 채팅하기로 바로 대화방에 진입한 경우
최초 한 번만 사용자에게 전달됩니다. 동일한 사용자가 재입장할때마다 웰컴블록이 노출되기를 원하실 경우 일반 블록을 웰컴블록과 동일하게 생성하여 유도하는 방식으로 응용할 수 있습니다.
Caution. 만약 웰컴블록이 동작하지 않는 경우 아래 내용을 체크하여 주시기 바랍니다. 웰컴블록은 ON/OFF를 설정할 수 있으며 OFF할 경우, 위 상황에 해당하는 경우에도 웰컴 블록의 메시지는 전송되지 않습니다. 웰컴블록은 최초 1회 진입시에만 확인 가능합니다. 알림톡과 함께 사용하는 채널인 경우 사용자가 채널추가를 한 경우에만 웰컴블록이 노출됩니다.
폴백 블록(Fallback Block) 설정하기
봇이 사용자의 말을 알아듣지 못하고, 이해할 수 없다는 의미의 메시지를 내뱉는 상황을 폴백(fallback) 상황이라고 합니다. 즉, 폴백 블록은 사용자의 입력(Input)이 어떠한 블록과도 매칭이 되지 않을 때의 응답을 설정하는 블록입니다.
폴백 메시지 작성을 위한 텍스트형 말풍선 작성 공간의 모습. 폴백 말풍선에 필요한 버튼도 추가할 수 있습니다
상기 화면처럼, 봇 작업자는 봇이 사용자의 말을 이해하지 못할 때 발송하는 첫 번째 메시지를 ‘텍스트형’ 말풍선 형태로 작성할 수 있습니다. 첫 번째 응답 부분의 + 버튼을 누르면, 여러 개의 텍스트형 말풍선을 작성할 수 있습니다. 이렇게 작성된 말풍선들은 폴백 상황에서 랜덤으로 사용자에게 출력됩니다. 바로 연결 응답 및 기타 말풍선들을 추가로 폴백 내용 말풍선에 이어서 추가할 수도 있습니다.
탈출 블록(Exit Block) 설정하기
탈출 블록은 사용자가 봇의 되묻기 상황에서, 강제적으로 빠져나가고자 할 때 쓰는 명령어를 정의하는 곳입니다.
탈출 블록 내에서 탈출 명령어로 쓰일 발화를 지정하는 모습
되묻기 상황을 탈출하기 위한 임의의 명령어 발화를 입력해두는 곳으로 이해하면 좋습니다. 되묻기 상황에서 쓸 수 있는 사용자의 탈출 수단이니, 탈출 블록에 정의된 명령어를 봇의 응대 시나리오 내 적정 지점에서 사용자에게 안내하는 것이 좋습니다.
인증 블록 설정하기
인증 블록은 플러그인을 사용하기 위한 블록입니다. 처음 봇을 생성할 당시에는 인증 블록이 없으며 이후 채널 – 앱을 정상적으로 봇에 연결하시면 인증 블록이 생성됩니다.
인증 블록의 모습
챗봇 관리자센터에서 인증 블록을 사용하시려면 아래와 같은 사전 설정이 필요합니다.
Step 1. 채널-앱 설정하기
인증 블록을 사용하기 위해서는 비즈니스 인증이 필수 입니다. 비즈 채널과 앱 을 연결 후 인증 블록을 사용할 수 있습니다.
Information. 카카오톡 비즈니스 채널(인증된 프로필)과 디벨로퍼스 비즈 앱 생성 방법은 카카오싱크 공통 가이드에서 상세하게 확인할 수 있습니다.
Step 2. 봇에 채널 설정하기
카카오비즈니스 관리자센터에서 운영, 개발 채널을 생성하고 동일한 앱에 연결을 완료하였다면 챗봇 관리자센터에서 해당 채널-앱을 설정 합니다. 상세한 설정 방법은 카카오톡 채널 연결하기를 참고하시길 바랍니다.
챗봇 관리자센터 내 ‘인증블록’에서 필수 파라미터 설정 후 일반 블록과 연결하여 플러그인을 이용할 수 있습니다.
Caution. 만일, 인증블록 설정 후 채널/앱 정보에 변동사항이 있는 경우 플러그인이 정상 동작하지 않을 수 있습니다.
아래 사항을 확인한 후 반드시 인증블록을 초기화 및 재설정 해주시기 바랍니다. 또한 인증블록과 연결된 블록 버튼도 재설정이 필요합니다.
운영 채널 또는 개발 채널만 연결되어 있는지 확인 – 두 채널 모두 봇과 연결 필요 두 채널이 모두 같은 앱에 연결되어 있는지 확인 – 두 채널이 같은 앱에 연결 필요
(운영, 개발채널 설정탭에서 채널의 빨간색 글씨 및 느낌표가 출력되는것은 운영, 개발채널에 연결된 앱이 서로 다른 경우) 디벨로퍼스 앱 제품 설정에서 ‘카카오 로그인 활성화’가 ON으로 되어 있어야 함 (싱크,회원가입 플러그인의 경우)디벨로퍼스 앱 제품 설정에서 ‘간편가입 사용 여부’가 ON으로 되어 있어야 함 봇 마스터가 채널과 연결된 디벨로퍼스 앱에 권한이 있는지 확인 – 봇 마스터가 채널과 연결된 앱에 EDITOR 이상의 권한 필요 (싱크,회원가입 플러그인의 경우)디벨로퍼스의 ‘카카오싱크 플러그인 Redirect URI’가 정상적으로 입력되어있는지 확인 – URI가 유효해야 함 설정을 완료한 후 운영채널에서만 동작하지 않는다면 ‘배포’를 시행했는지 확인
엔티티 설정하기
엔티티 등록하기
아래와 같이 두 가지 방법으로 챗봇 관리자센터에 엔티티를 등록할 수 있습니다.
엔티티에서 등록하기
엔티티 버튼을 눌러 엔티티를 미리 정의할 수 있습니다.
엔티티 설정 위치 : 봇 생성 후 우측 상단에서 확인 가능합니다.
엔티티 설정 팝업 화면: 엔티티 생성을 눌러 단어를 추가합니다.
미리 정의해 둔 엔티티가 있다면, 발화를 입력할 때마다 손쉽게 해당 엔티티를 사용자 발화 패턴에서 태깅이 가능하도록 밑줄 하이라이트가 표시 됩니다.
밑줄 하이라이트 : 예상 발화를 입력하면, 엔티티로 태깅 될 수 있는 단어가 밑줄로 표시됩니다.
엔티티 태깅: 밑줄로 하이라이트 된 단어를 마우스로 드래그 하면, 선택된 부분에 필요한 엔티티를 태깅할 수 있습니다. 봇 작업자가 부여할 수 있는 추천 엔티티, 또는 더 넓게 찾아볼수 있는 전체 엔티티 메뉴를 제공합니다.
엔티티 태깅 중 새 엔티티 추가하기 버튼을 통해 등록하기
봇 작업자는 발화 입력 후 중요하게 생각하는 단어를 즉시 엔티티로 만들 수 있습니다. 입력된 발화 중 특정 단어를 드래그하면 태깅이 가능한 엔티티 메뉴를 볼 수 있습니다. 필요에 따라 팝업창 하단의 새 엔티티로 추가하기 버튼을 통해 추가 엔티티 설정이 가능합니다.
발화 작성시 특정 단어 드래그를 통한 추가 엔티티 작성 및 반영 모습
블록 내 ‘발화입력’ 화면 : ‘라떼’에 해당하는 ‘coffee_name’ 엔티티가 매핑되어 박스로 표시되는 모습
나의 엔티티 작성 예시
엔티티 작성의 좋은 예
엔티티를 잘 작성한다는 것은 사용자의 발화문에서 의미있는 단어를 추출해내는 기초 작업을 튼튼히 하는 것을 뜻합니다. 그래야 발화 패턴을 인식하는 자연어처리 로직을 십분 활용할 수 있고, 다양한 발화 형태 속에 존재하는 중요한 단어를 보다 정확히 발췌할 수 있습니다. 올바르게 작성된 엔티티 예시는 아래와 같습니다.
바람직한 엔티티 작성 예시
Tip. 의미있는 데이터 중심으로 엔티티를 구분 합니다. 예) cafe_name(카페명), coffee_name(커피메뉴), user_action_order(사용자행동패턴), service_type(주문서비스방식))
엔티티 간 단어들이 중복되지 않고, 의미가 겹치지 않도록 합니다.
엔티티 목록만 보아도 누구나 의미를 쉽게 유추할 수 있도록, 엔티티명을 명확하게 정의합니다.
엔티티 작성의 나쁜 예
봇 디자이너가 사용자 발화의 모든 형태를 정확한 매칭(exact matching)으로 잡아내겠다는 의지로 모든 발생 가능할 단어를 엔티티로 등록해버리면 발화 패턴이 매우 복잡해집니다. 뿐만 아니라 향후 엔티티 유지보수 또한 어려워지게 됩니다. 결국엔 하나의 등록으로 충분한 발화패턴을, 굳이 수십여개로 만들어내야하는 엔티티 작성 부담을 불필요하게 발생시킬수 있습니다. 엔티티 작성의 핵심 포인트는, 사용자 발화입력 패턴을 잡아내는데 있어서 가장 필수적인 단어(또한, 여러 형태로 변경 가능한 단어)를 엔티티로 일괄 등록하는 것 입니다.
부적절한 엔티티 작성 예시는 아래와 같습니다.
사용자가 엔티티 등록시 지양해야하는 작성 예시
Tip. ‘좀, 그렇게, 어떻게’ 등 발화문장에서 큰 의미가 없는 모든 발생가능한 단어들을 엔티티로 등록하는 것은 피하도록 합니다. 엔티티 태깅을 통해 중요 정보를 추출해내는 관점에서 크게 중요하지 않기 때문입니다.
유의미한 데이터로 구성한 카테고리가 아닌, 사용자 발화 중 중요하지 않은 단어들을 모두 번거롭게 등록할 필요는 없습니다. 향후 의미없는 작업노고를 발생시키는 원인이 됩니다. 예) ‘네’, ‘갑니다’, ‘주세요’, ‘안되겠네’ 등과 같은 서술어미 종류
발화 패턴 만들기
봇 작업자가 사용자 발화 패턴 설정란에 사용자 예상 발화를 입력하고 난 후, 직접 태깅을 통해서 필요한대로 발화 패턴을 정의할 수 있습니다. 챗봇 관리자센터에서는 태깅이 필요할 것으로 예상하는 엔티티 단어에 대해서 밑줄(Underline)을 자체적으로 표시해주는데, 이를 확인하고 봇 작업자는 밑줄이 가르치는 단어를 드래그하여 필요한 엔티티를 직접 부여하실 수 있습니다.
다음과 같은 작업 순서 예시를 확인하십시오.
Step 1. 발화 중 밑줄이 표시된 ‘라이언’에 인물 엔티티를 태깅합니다. (엔티티명: @sys.person.name )
밑줄이 나타난 단어를 드래그하면, 엔티티를 고를수 있는 팝업이 나타납니다. 필요에 따라 봇 작업자는 추천 엔티티 또는 전체 엔티티 목록에서 희망하는 엔티티를 부여할 수 있습니다.
Step 2. 밑줄이 없더라도 ‘나이’처럼 특정 단어에 엔티티 태깅을 할 수 있습니다. (엔티티명 : @age )
나이라는 단어에 직접 드래그 하여 별도의 엔티티를 강제 부여하는 모습입니다.
입력된 발화에 대해서 최종적으로 엔티티 태깅이 완료하고 나면 패턴 발화가 생성됩니다.
Step 3. 의도 확인에 중요한 정보는 {sys.person.name} , {age} 엔티티에 있음을 확인합니다.
패턴이 잡혀진 발화의 예시 모습입니다.
결론적으로 본 테스트 블록의 사용자 의도는 나이 묻기이며, 이러한 의도를 확인하기 위한 패턴은 아래와 같다는 것을 알 수 있습니다.
패턴 발화 : {인물이름} {나이} <어떻게> <되다>
위 같은 방식으로, 본 블록이 나타내고자 하는 의도에 알맞는 발화패턴을 입력하고 태깅하는 작업하는 과정을 이어서 하면 됩니다. 하나의 블록 안에서 패턴을 충분히 포함 할 수록, 실제 사용자 발화에 블록이 대응할 수 있는 확률이 높아집니다.
되묻기 질문 등록하기
되묻기 질문은 챗봇이 대화 중에 사용자에게 거꾸로 질문을 던지는 액션을 말합니다. 봇은 대화를 이해하며 사용자와 인터랙션을 이어가기 위해 사용자 발화 안에 특정 값이 있는지 지속해서 확인하고, 필요로 하는 값이 있다면 이를 추출하여 외부 스킬 서버 및 플러그인과 연동합니다. 특정한 의도가 있는 응답을 구현하기 위해서는, 사용자 발화로부터 특정 값이 필수적으로 접수 되어야 합니다. 만약 발화 중 특정 필수 값이 부재한다면, 봇 사용자가 해당 값을 입력하도록 유도하는 되묻기 질문을 설정할 수 있습니다.
챗봇 관리자센터 안에서는 봇이 받고자 하는 값을 사용자 발화 안에 있는 엔티티를 통해서만 인지할 수 있는데, 이러한 엔티티를 칭하여, 새로운 파라미터로 정의합니다. (주요개념 > 파라미터 설정에서 더 상세하게 확인할 수 있습니다.) 이때, 되묻기 기능을 사용하기 위해서는 해당 파라미터를 ‘필수’로 표시하여 필수 파라미터로 설정해야 합니다. 아래 예시를 통해 커피를 주문하는 의도를 가진 블록에서 되묻기 기능을 활용하는 과정을 볼 수 있습니다.
필수 파라미터 설정하기
봇 작업자는 발화 ‘주문 할게요.’를 등록하였습니다. 그리고 해당 블록이 실행될 때 사용자 예상 발화 안에 커피 이름(CoffeeName) 과 수량(CupCount)을 필수 파라미터로 설정하였습니다. 이때 필수 파라미터 박스안에서 되묻기 질문 버튼이 활성화 된 것을 확인할 수 있습니다.
되묻기 질문이 필수 파라미터 설정을 통해 활성화 된 모습입니다. 되묻기가 정상적으로 끝나 필요 파라미터 값이 모두 수신되면 설정한 응답형식이 출력되는 형태입니다.
되묻기 질문 설정하기
되묻기 질문 버튼을 클릭하면 각 필수 파라미터에 값이 채워지도록, 사용자를 유도하는 되묻기 질문을 설정할 수 있습니다. 각 필수 파라미터에 대한 되묻기 질문 작성 예시는 다음 화면과 같습니다.
CoffeeName 파라미터를 얻기 위한 되묻기 설정 화면: 사용자가 주문할 커피 이름을 묻는 질문으로 구성되었습니다
CupCount 파라미터를 얻기 위한 되묻기 설정 화면 : 사용자가 주문하고자 하는 수량을 묻는 질문으로 구성되었습니다
되묻기 질문 팝업의 상세 메뉴 구성은 다음과 같습니다.
되묻기 질문 응답 : 되묻기 질문을 정의합니다. 총 3개까지 정의할 수 있고, 사용자에게 출력되는 허용횟수 안에서 무작위 순으로 출력됩니다.
: 되묻기 질문을 정의합니다. 총 3개까지 정의할 수 있고, 사용자에게 출력되는 허용횟수 안에서 무작위 순으로 출력됩니다. 바로 연결 응답 : 사용자가 되묻기 상황에서 입력할 파라미터 값을 직접 ‘바로 연결’ 버튼으로 클릭해 보낼 수 있도록 세팅합니다.
: 사용자가 되묻기 상황에서 입력할 파라미터 값을 직접 ‘바로 연결’ 버튼으로 클릭해 보낼 수 있도록 세팅합니다. 되묻기 허용 횟수 설정 : 되묻기 질문이 실행될 횟수를 선택합니다. 최대 허용 횟수가 끝나서 결국 원하는 파라미터값을 획득하지 못했을 때 봇이 사용자에게 출력할 안내 메시지를 정의합니다.
설정된 되묻기 질문 확인하기
모든 설정을 마친 후, 카카오톡 화면에서 최종 응답을 아래 화면과 같이 확인할 수 있습니다. 봇은 되묻기 질문을 통해 필수 파라미터 값인 커피이름 아메(아메리카노의 약자)와 커피수량 2를 수신받고 최종 응답을 출력하였습니다.
커피 주문 – 되묻기가 모두 실행된 카카오톡 사용자 화면
컨텍스트 사용하기
챗봇 관리자센터의 고급 기능 중에 하나인 컨텍스트를 손쉽게 쓸 수 있도록, 다음과 같이 세 가지 활용 방법을 안내합니다.
컨텍스트 조건 설정하기
먼저, 시나리오 > 블록 > 컨텍스트 설정에서 컨텍스트 명칭을 등록합니다. (설정 개수에는 제한이 없습니다)
컨텍스트 설정 선택 팝업 위치
다른 블록으로 컨텍스트를 내보낸다면, Output 컨텍스트에 명칭을 등록합니다.
Output 컨텍스트에 Ordering 이라는 컨텍스트 명칭을 등록중인 화면
다른 블록에서 내보낸 컨텍스트를 받는다면, Input 컨텍스트에 명칭을 등록합니다.
Input 컨텍스트에 Ordering 이라는 컨텍스트 명칭을 등록중인 화면
특히, Output 컨텍스트 부분은 봇 작업자들이 컨텍스트를 생성하여 연결할 때 가장 먼저 설정 작업을 하고, 주요 정보를 등록하는 중요한 공간입니다.
Output 컨텍스트를 등록할 때는 필수로 다음 세 가지를 입력해야 합니다.
컨텍스트 구성 값 의미 값 비고 컨텍스트 명칭 컨텍스트 내용을 설명하는 이름 컨텍스트 수명 컨텍스트가 지속되는 블록 횟수 0/1/3/5/10 (회) 끝나면 컨텍스트가 만료됩니다.
0은 즉시 만료됩니다.(초기화) 유효시간 컨텍스트가 지속되는 시간 1/3/5/10/15/30/60 (분) 끝나면 컨텍스트가 만료됩니다.
Output 컨텍스트의 수명 정보 설정 모습
Output 컨텍스트의 유효 시간 정보 설정 모습
컨텍스트 정보를 스킬 요청(request)에서 활용하기
컨텍스트에 담겨진 정보는 스킬 요청시에도 사용할 수 있습니다. 아래 화면과 같이 블록 안의 파라미터 만들기 메뉴 안에서 ‘값’ 입력란에, 원하는 컨텍스트와 파라미터 명을 다음 형식을 따라 참조할 수 있습니다.
파라미터 설정 안에서 파라미터 만들기 메뉴 안의 ‘값’ 설정 부분
형식
#[컨텍스트명].[파라미터명]
반드시 참조한 컨텍스트를 내보내는(Output) 블록이 존재해야 하며, 설정중인 블록에서 해당 컨텍스트를 받아야(Input) 합니다. 이처럼 블록 간 컨텍스트가 설정되어 있지 않다면, 컨텍스트와 파라미터명을 참조해도 동작하지 않습니다.
형식 예시
컨텍스트 정보를 스킬 응답(response)에서 활용하기
스킬 응답에서 ‘Output 컨텍스트’의 정보를 직접 업데이트 할 수 있습니다. 예를 들어 다음과 같은 스킬 응답 포맷이 있다고 하겠습니다.
{ “version” : “2.0” , “template” : { … }, “context” : { “values” : [{ “name” : …, “lifeSpan” : …, “params” : … },{ “name” : …, “lifeSpan” : …, “params” : … }, … ] } }
스킬 응답의 Structure 예시
다음처럼,
복수의 Output 컨텍스트들 중 특정 컨텍스트만 Output 되도록 변경할 수 있습니다. → name
컨텍스트의 수명(lifespan)을 변경할 수 있습니다. → lifeSpan
컨텍스트와 관련해 전달하고 싶은 값을 추가할 수 있습니다. → params
스킬 응답의 Output 컨텍스트에 들어있는 내용이 현재 블록의 Output 컨텍스트란에 존재하는 경우에는, 스킬에 들어있는 값으로 현재 Output 컨텍스트를 덮어쓰기합니다.
Information. 인풋(Input)으로 설정한 컨텍스트가 만료될 경우 해당 블록은 설정된 응답이 아닌 폴백 메시지로 응답하게 됩니다. 폴백 메시지가 설정되어 있지 않으면 빈 말풍선이 나가게 되므로 기본 시나리오> 폴백블록 에서 설정 상태를 확인해 주세요.
컨텍스트 갱신
스킬 응답으로 컨텍스트를 수정하는 경우, 변경하려는 output 컨텍스트가 미리 블록에서 설정되어야 합니다. 스킬 응답의 context 필드는 값을 수정할 뿐, 새로운 output 컨텍스트를 만들 수는 없습니다.
Example. 예를 들어 abc 라는 output 컨텍스트를 블록에서 생성했다면, 스킬 응답으로 abc name을 가지는 context의 lieSpan, params를 수정할 수 있습니다.
하지만 def 라는 output 컨텍스트를 블록에서 생성하지 않은 상황에서, 스킬 응답으로 def 라는 name을 가지는 context를 수정한다면 이는 반영되지 않습니다.
응답 타입별 JSON 포맷 > ContextControl
봇 학습시키기
학습대기에서 발화를 학습 하는 방법
Step 1. 학습대기 목록에서 블록에 매칭시킬 발화를 선택합니다.
학습대기 목록에 노출된 2018년 11월 14일에 들어온 폴백 발화들
학습대기 목록은 설정된 기간동안 들어온 폴백 발화들을 빈도가 높은 순으로 정렬하여 노출합니다.
Step 2. 발화 학습 상세화면에서 매칭 블록을 지정하거나 엔티티를 태깅 후 학습을 누릅니다.
학습대기목록에서 빠히바게트에서 빵이요 발화를 선택하고 엔티티 태깅 후 베이커리 주문 블록으로 연결
연결블록을 지정하지 않으면 무시만 가능하고 연결블록을 지정해야 학습 버튼이 활성화 됩니다.
Step 3. 학습한 발화는 매칭한 블록으로 등록되고 학습대기에서 학습이력으로 이동됩니다.
베이커리 주문 블록에 학습대기에서 매칭했던 빠히바게트 빵이요 발화 및 엔티티 추가된 화면
학습이력에서 학습시킨 발화는 학습이력으로 이동되고 업데이트일, 학습상태가 목록에 노출
학습이력에서 이미 학습한 발화를 변경하는 방법
Step 1. 이미 학습한 발화를 선택하기 위해 학습이력 목록을 들어갑니다.
11월 1일 에서 11월 15일까지 학습한 이력들
Step 2. 학습이력 목록에서 학습한 빠히바게트에서 빵이요를 선택하고 연결 블록을 변경합니다.
학습이력 팝업에서 빠히바게트에서 빵이요 발화가 베이커리 주문 블록에서 빠히바게트 블록 으로 변경된 화면
학습이력의 상세화면에선 선택한 발화를 업데이트 한 일시, 작업자ID가 표기되고 발화 연결블록과 엔티티 정보가 함께 노출됩니다. 학습이력에서 무시한 문장은 블록에 매칭될 경우 매칭되었던 블록에서 발화가 삭제되고 다시 폴백 블록으로 매칭되어, 사용자가 해당 발화를 다시 입력한 경우에도 학습대기 목록에 노출되지 않습니다.
Step 3. 변경한 발화는 기존 블록에서 삭제되고 매칭한 블록에 새롭게 등록됩니다.
빠히바게트에서 빵이요 발화가 베이커리 주문 블록에서 빠히바게트 블록 으로 변경된 화면
학습 대기 목록 필터링 하기
기간 변경
학습대기 에선 어제까지의 날짜, 학습이력에선 오늘을 포함한 어제 날짜를 선택할 수 있습니다.
기간 탭에서 어제를 선택하면 현재일 전날의 날짜가 지정됩니다. 학습이력에서 어제를 선택하면 어제부터 오늘까지의 날짜가 선택됩니다
날짜 탭을 선택하여 직접 조회할 날짜를 선택할 수 있습니다.
달력에서 날짜를 직접 지정할 경우 목록조회 시작 날짜와 종료 날짜를 지정할 수 있습니다. 설정할 수 있는 기간은 최대 30일 입니다.
검색필터 추가
학습대기 목록에서 검색필터를 추가하여 목록을 필터링 할 수 있습니다. 검색 필터 추가 버튼을 누른 후 텍스트 메뉴에서 발화포함 혹은 발화제외를 지정하면 검색할 단어(최대 12자)를 입력할 수 있습니다. 발화 값에서 발화빈도 혹은 빌화길이를 선택하면 일정 숫자 이상 혹은 이하의 숫자(최대 99,999,999)를 입력하여 필터링 할 수 있습니다.
학습대기에서 텍스트 검색필터 조건을 발화포함 으로 하고 아니 라는 단어를 입력
설정된 기간동안 발화에 아니 가 포함된 목록과 빈도
일반사용자 봇과 카카오톡 채널 연결하기
카카오톡 채널은 카카오톡 채널 관리자센터에서 생성하기
Step 2. 인증 및 이용약관 동의
Step 3. ‘새 채널 만들기’ 클릭
Step 4. 채널 정보 입력하기
Step 5. 채널 개설 완료
카카오톡 채널 연결하기
카카오톡 채널 연결은 봇 설정에서 간단하게 연결할 수 있습니다.
만약 채널 연결이 불가하다면 아래 내용을 확인하여 주시기 바랍니다.
봇은채널과 1:1의 구조로, 다른 봇에 채널이 연결되어 있을 경우 추가로 연결할 수 없습니다.
[카카오톡 채널관리자 센터 > 스마트채팅 > 채팅방메뉴]의 채팅방 메뉴 사용 설정이 ON으로 되었는지 확인 부탁드립니다. 채팅방 메뉴와 챗봇은 동시사용이 불가하므로, 채팅방 메뉴 사용 설정을 OFF로 하면 채널이 챗봇과 연결 가능한 상태로 변경됩니다.챗봇에선 마스터권한, 채널에서는 매니저 이상의 권한일 경우 연결 가능합니다.
Step 1. 설정 메뉴의 ‘카카오톡 채널 연결’ 영역으로 이동
Step 2. ‘운영 채널’의 선택 영역 클릭
Step 3. ‘개발 채널’의 선택 영역 클릭
지식 베이스 설정하기
지식 관리자센터에서 지식 베이스를 생성하여 질문과 답변 데이터를 관리하고 있다면, 봇과 연동할 수 있습니다. 지식 베이스란?
지식 베이스 설정
설정 메뉴의 지식 베이스 정보를 통해 봇 작업자는 지식 베이스를 설정할 수 있습니다. 봇 작업자는 자신이 마스터 권한으로 있는 지식 베이스를 선택하여 연동할 수 있습니다.
지식 베이스를 선택하고, 지식 베이스의 버전을 선택하는 방식은 2가지가 있습니다.
(1) 수동 선택한 버전을 사용
봇 작업자가 특정 버전을 선택하여 사용할 수 있습니다. 설정 후, 봇 배포를 해야 운영 채널에도 설정한 지식 베이스 버전이 반영됩니다.
(2) 최신 배포 버전을 사용
봇 작업자는 항상 지식 베이스의 최신 배포 버전을 사용할 수 있습니다. 단, ‘최신 배포 버전을 사용’ 설정 후에 봇을 배포해야 운영 채널에 해당 설정이 반영됩니다. 설정 후, 1회의 봇 배포 이후에는 별도의 봇 배포 없이도 운영 채널에 지식 베이스의 최신 배포 버전이 적용됩니다.
답변 출력 종류
지식 베이스를 설정하셨다면, 카카오톡에서 답변의 출력 형태를 정해야 합니다.
답변 출력 형태는 아래와 같이 3가지가 있으며, 용도에 맞게 답변 형태를 선택하시면 됩니다.
질의자의 질문형태에 가장 정확한 것으로 판단되는 답변하나만 전달하는 즉문즉답형
정확도순으로 Top3 유사질문 리스트를 보여주는 답안추천형
사용자가 스킬을 이용하여 자유롭게 답변을 구성하는 스킬형
답변출력 형태 예시 – (1) 즉문즉답형 (2) 답안추천형 (3) 스킬형
답변 출력 설정 방법
(1) 즉문즉답형 말풍선 설정
즉문즉답형 출력 말풍선에서는 다음의 3가지를 설정할 수 있습니다.
최소 답변 정확도 답변 제공의 기준이 되는 최소 정확도를 설정하는 영역입니다. 설정된 정확도 이상의 지식 베이스 답변을 제공합니다.
가이드 말풍선 답변이 제시되기 전에 안내문구를 꾸미는 영역입니다. 텍스트로 가이드문구를 넣어주거나, 또는 희망하시는 이미지를 넣어줄수 있습니다. 이 부분을 선택적으로 On/Off할수도 있습니다.
피드백 버튼 답변이 제공된후, ‘좋아요’ 또는 ‘나빠요’에 해당하는 사용자 피드백 버튼을 넣어줄수 있습니다. 이 부분도 선택적으로 On/Off할수 있습니다.
*참고. 피드백 버튼으로부터 누적된 결과를 바탕으로 답변 검색 로직을 강화하고, 분석 메뉴에서 블록별로 현황을 보여주는 feature가 향후 데이터 누적후 제공될 예정입니다.
(2) 답안추천형 말풍선 설정
답안추천형 출력 말풍선에서는 다음의 4가지를 설정할 수 있습니다.
가이드 말풍선 즉문즉답형에서 꾸미는 방식과 동일합니다. 답변 출력전 안내문구를 넣어주거나 이미지를 넣어줄수 있습니다.
답변설정 답안추천형에서는 사용자 질의 문장에 대해 유사한 것으로 판단되는 유사질문 Top3를 캐로셀 형태로 제공합니다. 이때, 봇작업자는 이미지를 첨부하여 카드형 말풍선으로 답변을 꾸밀수 있습니다.
<사용법 참고>
이미지가 필수로 들어가는 카드형 말풍선에서 봇 작업자가 기존에 저장해 둔 Q&A 지식 정보 세트 정보 중에서 image info (URL)에 해당하는 정보가 있다면 → 우선적으로 해당 image info 이미지가 보여집니다.
image info (URL)가 없다면 → 위에서 사용자가 파일로 업로드한 이미지가 디폴트로 출력됩니다. 예시로, 추출된 Top3 유사질문 리스트에서, 1개만 image url 정보가 있었고 2개는 image url정보가 없었다면, 해당 2개의 이미지는 봇 작업자가 여기 말풍선 상세 메뉴에서 업로드 해 둔 디폴트 이미지가 출력되는 것입니다.
버튼명 설정 답변을 보기 위한 버튼에 대해 ‘버튼명’을 정의할수 있습니다.
피드백 설정 답변이 제공된후, ‘좋아요’ 또는 ‘나빠요’에 해당하는 사용자 피드백 버튼을 넣어줄수 있습니다. 선택적으로 On/Off할수 있습니다.
(3) 스킬형형 말풍선 설정
스킬형을 선택하면 발화가 지식 베이스의 질문에 일치하는 경우, 스킬 payload를 통하여 지식의 목록과 정보가 전달됩니다.
스킬형 출력 말풍선에서는 다음의 2가지를 설정할 수 있습니다.
스킬 설정 지식 정보를 전송할 스킬을 선택할 수 있습니다. 스킬 선택을 위해서는 ‘스킬’ 메뉴에서 스킬을 등록해야 합니다.
최소 답변 정확도 답변 제공의 기준이 되는 최소 정확도를 설정하는 영역입니다. 설정된 정확도 이상의 답변 정보를 제공합니다.
SkillPayload
스킬 payload는 스킬 실행시 봇 시스템이 스킬 서버에게 전달하는 정보입니다. payload는 사용자의 정보, 발화, 실행 블록, 파라미터 등의 정보를 포함합니다.
intent
userRequest
bot
action
intent
발화와 일치하는 블록의 정보를 담고 있는 필드입니다. 발화가 지식 베이스 질문과 일치하는 경우, 일치하는 지식의 목록을 포함합니다.
상세필드
이름 타입 설명 id string 블록 id입니다. name string 블록명이며, 지식의 경우 “지식+”로 노출합니다.
상세필드
이름 타입 설명 matchedKnowledges array 발화에 일치한 지식 목록입니다.
knowledge
상세필드
이름 타입 설명 answer string 지식의 답변입니다. question string 지식의 질문입니다. categories array QA의 카테고리입니다. landingUrl string 지식 답변에서 링크 더보기입니다. imageUrl string 답안 추천형 지식 답변에서 썸네일 이미지입니다.
에제 코드
{ “bot” : { “id” : “<봇 id>” , “name” : “<봇 이름>” }, “intent” : { “id” : “<블록 id>” , “name” : “지식+” , “extra” : { “reason” : { “code” : 1 , “message” : “OK” }, “knowledge” : { “responseType” : “skill” , “matchedKnowledges” : [ { “categories” : [ “<카테고리 1>” , “<카테고리 2>” , “<카테고리 3>” , “<카테고리 4>” ], “question” : “<질문>” , “answer” : “<답변>” , “imageUrl” : “<이미지 url>” , “landingUrl” : “<랜딩 url>” }, { “categories” : [ “<카테고리 1>” , “<카테고리 2>” , “<카테고리 3>” , “<카테고리 4>” ], “question” : “<질문>” , “answer” : “<답변>” , “imageUrl” : “<이미지 url>” , “landingUrl” : “<랜딩 url>” } ] } } }, “action” : { “id” : “<액션 id>” , “name” : “<액션 이름>” , “params” : {}, “detailParams” : {}, “clientExtra” : {} }, “userRequest” : { “block” : { “id” : “<블록 id>” , “name” : “<블록 이름>” }, “user” : { “id” : “<사용자 botUserKey>” , “type” : “botUserKey” , “properties” : { “botUserKey” : “<사용자 botUserKey>” , } }, “utterance” : “<사용자 발화>” , “params” : { “surface” : “BuilderBotTest” , “ignoreMe” : “true” }, “lang” : “kr” , “timezone” : “Asia/Seoul” }, “contexts” : [] }
패턴발화가 등록된 블록과 연계한 응용 활용 방법
사용자 질의에 응대하기 위해 이미 패턴발화를 블록에 수없이 등록했는데, 본 메뉴에서도 지식정보 Q&A 세트를 또 업로드해서 사용할 수 있는 것인가요? 두 개 메뉴에 해당하는 기능을 동시에 사용할 수 있나요?
물론입니다.
패턴발화를 등록한 블록들과, 지식 베이스 설정에 대한 ‘배포’ 과정을 통해 하나의 봇을 만들수 있습니다. 단, 이때에는 사용자 질의에 대해, 우선적으로 패턴발화를 등록했던 블록 중에서 정확하다고 판단되는 블록이 선택되어 그에 연결된 답변이 출력됩니다.
만약 사용자 의도가 추출이 되지 않는 질문이라고 하면 그 다음에 순차적으로 지식 베이스에서 유사 질문이 검색되어 연결된 답변이 출력됩니다. (즉, 챗봇이 질문을 이해하지 못하여 ‘폴백’ 메시지를 내놓을수 있는 확률이 줄어듭니다.)
그러므로, 봇작업자께서는 보다 중요하고 의미있는 질문들을 처리하기 위한 내용들은 시나리오 메뉴의 ‘블록’들을 통해 답변 작성을 해두시고, 이외 기타 수많은 형태의 질문-답변 세트는 지식 베이스에 업로드하면, 사용자 질의에 대해서 보다 답변 응대력이 향상된 봇을 만들수 있습니다.
Tip. 시간이 없고, 무조건 빨리 시일내 가장 기본적인 봇을 만들려고 한다면, 시나리오에 블록을 만들지 않고서도, 지식 베이스 설정으로 ‘간단 답변 검색형’ 봇을 만들수도 있습니다..
머신러닝 사용하기
머신러닝을 사용하여 똑똑한 챗봇을 만들기 위해서는 크게 4가지 단계를 거쳐야 합니다. 그럼 아래에서 하나씩 살펴볼까요?
머신러닝 발화 입력
머신러닝을 하기 위해서는 머신러닝 발화가 필요합니다. 그리고 머신러닝 발화를 입력하는 방법은 아래 3가지가 있습니다.
Step 1. 직접 입력
우선 머신러닝 발화를 직접 입력하는 방식이 있습니다. 이 방식을 사용하기 위한 방법은 아래와 같습니다.
1.1 블록 상세에서 머신러닝 발화 관리 버튼을 눌러주세요.
1.2 머신러닝 발화 관리 팝업에서 머신러닝 발화를 입력해주세요.
Step 2. 패턴 발화 복사
머신러닝 발화를 따로 입력하시는게 귀찮고, 번거로우시다면 패턴 발화에 입력된 발화를 복사하여 머신러닝 발화에 붙여넣는 기능이 있습니다. 패턴 발화와 머신러닝 발화를 따로 관리하지 않아도 된다는 것이 장점인 기능입니다. 사용 방법은 아래와 같습니다.
2.1 머신러닝 발화 관리 팝업에서 ‘패턴 발화를 머신러닝 발화로 복사’ 기능을 ON으로 바꿔주세요.
2.2 패턴 발화가 머신러닝 발화로 복사된 것을 확인하실 수 있습니다.
Caution. 패턴 발화 복사는 최신 입력순으로 최대 2000개 까지만 복사됩니다.
까지만 복사됩니다. 기능을 해제하면 복사되었던 모든 패턴 발화가 삭제됩니다.
Step 3. 업로드
혹시 서비스를 위한 사용자 예상 발화를 엑셀로 관리하고 계셨나요? 많은 발화를 한번에 업로드할 수 있는 방식도 있습니다. 사용법은 아래와 같습니다.
3.1 머신러닝 발화 관리 팝업에서 기능탭의 ‘파일 업로드’를 눌러주세요.
3.2 utf-8로 인코딩된 CSV로 발화를 업로드해주세요. 샘플 파일 받기
Caution. 업로드 파일은 CSV utf-8 만 지원합니다. 샘플 파일 받기
만 지원합니다. 샘플 파일 받기 업로드는 한번에 최대 2000개까지 지원합니다.
머신러닝 발화 작성 시, 똑똑한 챗봇을 만들기 위한 몇 가지 팁을 다음과 같이 알려드립니다.
TIP 서술어를 다양하게 쓰기
예) 노래 틀어줘 , 노래 불러봐 , 노래 시작 등 엔트리를 다양하게 쓰기
예) 아이유 노래, 방탄 노래, 너바나 노래, 스탄 게츠 노래 등 어순을 다양하게 쓰기
예) 노래 틀어줘, 틀어줘 노래 등
Caution. 동일한 서술어, 어순, 엔트리를 많이 입력할 경우, 오버피팅 현상이 발생하여 챗봇의 인탠트 구분 정확도가 떨어질 수 있습니다.
머신러닝 실행
머신러닝 발화를 모두 입력했다면 이제 학습 모델을 만들기 위하여 머신러닝을 실행하셔야 합니다! 그 전에 머신러닝을 실행하기 위한 조건이 충족되었는지 확인 한 번 해볼까요?
머신러닝 실행 조건은 아래와 같습니다
(1) 2개 이상의 머신러닝 대상 블록
(2) 각 블록당 패턴 발화 1개 이상, 머신러닝 발화 20개 이상 존재
만약 실행 조건을 충족시키셨다면 실행 방법은 간단합니다. 아래를 참조해주세요.
오른쪽 상단의 머신러닝 실행 버튼을 눌러주세요.
머신러닝 대상 블록과 예상 소요 시간을 확인하고, ‘실행’ 버튼을 눌러주세요.
머신러닝 예상 소요 시간을 확인할 수 있으며, 예상 소요 시간이 길 경우에는 ‘확인’ 버튼을 눌러 머신러닝 진행과 병행하여 작업을 할 수 있습니다.
성능 테스트 및 최소 답변 정확도 조절
한 번의 머신러닝 실행이 끝났다고 챗봇이 완벽해지기는 힘듭니다. 그래서 학습 모델의 완성도를 측정하기 위해 테스트를 진행해야 합니다.
테스트를 위해서는 우선 테스트 발화 세트를 구성해야합니다. 구성 방법은 아래와 같습니다.
기존의 패턴 발화, 머신러닝 발화에 입력된 발화 말고, 새로운 발화를 모읍니다. 간단한 발화로 작동하는 블록은 5~10개, 복잡한 발화로 작동될 수 있는 블록은 20~30개정도를 준비합니다.
테스트 발화가 준비되었다면, 이제 챗봇에 테스트 발화를 입력하시면 됩니다.
테스트를 진행해보면 발화를 입력하고 연결된 블록이 적절하지 않거나, 틀린 경우가 발생할 수 있습니다. 이럴 경우에는 최소 답변의 정확도를 설정하여 정확도가 낮은 발화에 대해 블록이 연결되지 않게 설정할 수 있습니다.
최소 답변 정확도 설정은 ‘머신러닝’ 페이지에서 할 수 있으며, 설정값이 높을수록 정확도가 높은 발화에 대해서만 블록을 연결합니다.
최소 답변 정확도 답변 제공의 기준이 되는 최소 정확도를 의미합니다. 예를 들어, 최소 답변 정확도가 100이라면 정확도가 100인 답변만 제공하며, 최소 답변 정확도가 60이면 정확도가 60 이상인 경우에만 답변을 제공합니다.
머신러닝의 최소 답변 정확도는 머신러닝 페이지에서 설정이 가능하며, 지식+의 최소 답변 정확도는 즉문즉답형 응답에서 설정할 수 있습니다.
오매칭 발화 추가 입력
챗봇이 모든 테스트 발화에 제대로 작동하나요? 만약 생각보다 정답률이 낮다면 아래의 방법으로 챗봇을 튜닝해주세요.
오매칭 발화와 비슷한 발화를 머신러닝 발화에 입력 오매칭 발화를 패턴발화에 입력
이 방법을 반복하시면, 정말 똑똑한 봇을 만드실 수 있습니다!
Event API 사용하기
Event API 사전 설정
Event API 메시지를 발송하기 위해서는 다음과 같은 사전 설정이 필요합니다.
Step 1. 비즈니스 인증 채널과 디벨로퍼스 앱 연결하기
비즈니스 인증을 받은 채널과 비즈니스 인증을 받은 앱을 연결해야 합니다. 비즈니스 인증 채널을 신청하실 때에는 실제 서비스에서 사용할 카카오톡 채널로 신청해야 합니다.
Caution 이 때 디벨로퍼스 앱 사용자 설정에서 “카카오 로그인 활성화” ON 필수입니다.
봇을 제작하는 마스터가 카카오톡 채널 관리자센터에서 비즈 카카오톡 채널 인증을 받고 카카오 디벨로퍼스에서 비즈앱 인증을 각각 받습니다. 그리고 카카오비즈니스 관리자센터에서 위에서 만든 비즈니스 인증 채널 및 비즈 앱을 연결해줍니다. 카카오비즈니스 관리자센터 > 카카오싱크 신청 1단계: 채널-앱 연결하기 화면
Step2. 챗봇 관리자센터에 카카오톡 채널 연결하기
Event API를 사용하기 위해서는 챗봇 관리자센터에 카카오톡 채널 연결해야 합니다.
(운영채널과 개발채널 모두 Event API 발송을 지원하나 개발채널의 경우 이벤트 블록 호출 API url 내 파라미터값의 형태가 다릅니다. 자세한 내용은 개발가이드를 참고해주세요.)
챗봇 관리자센터 내 Event API 설정
챗봇이 건낼 수 있는 다양한 메시지 중 정확히 어떤 메시지(블록)를 전송할 지 정의해야 합니다. 이를 정의하기 위해서는 해당하는 블록 내에서 이벤트 이름을 설정하는 과정이 필요합니다.
블록 > […] > 이벤트 설정 > 이벤트 설정 팝업 에서 이벤트 이름을 작성한 뒤 엔터를 누르고 확인 버튼을 눌러주세요.
광고성 내용 포함
발송하려는 메시지가 광고성 내용을 포함하는 경우 이벤트 설정 팝업의 “광고성 내용 포함” 토글을 ON해야 합니다. 자세한 내용은 Event API 광고표시 의무 를 확인해주세요.
이벤트 이름은 중복되어 저장될 수 없습니다. 동일 봇에서 동일 이벤트명을 사용 중인 경우, 다음과 같은 경고 알림이 노출됩니다.
Event API 를 설정한 블록에서는 필수 파라미터를 지원하지 않습니다. 필수 파라미터가 설정된 경우, Event API 메시지가 발송되지 않으니 주의해주시길 바랍니다.
챗봇 관리자센터에서 Event API 설정 및 시나리오 수정을 완료한 뒤에는, 배포를 완료해야 Event API 메시지 발송이 가능합니다.
Event API 광고표시 의무
한국 인터넷 진흥원 광고표시 가이드
한국 인터넷 진흥원에서 배포한 불법 스팸 방지를 위한 정보통신망법 안내서에 따라 광고성 메시지 작성 시에는 하기 가이드를 준수하여야 합니다. 아래 내용을 참고하여 발송할 메시지가 광고성 내용을 포함할 경우, 말풍선 설정에서 광고성 내용 포함을 체크해야 합니다.
한국 인터넷 진흥원 광고표시 가이드
1. 광고표시 광고성 내용이 포함된 메시지 맨 앞에 (광고)를 표시해야 합니다.
광고성 메시지에 대한 판단 기준
1)특가/할인 상품 안내
2)상품 및 서비스 홍보를 위한 프로모션 또는 이벤트
3)정보를 ‘주’로 나타내더라도 [위 1,2]의 내용이 혼재된 경우
2. 전송자의 연락처 표시 의무사항
전송자의 명칭, 전송자 연락처는 메시지 본문보다 상단에 작성되어야 합니다.
전송자 명칭과 전송자 연락처의 경우 채팅방 상단에 노출됩니다.
연락처의 경우 전화번호 또는 주소 중에서 하나를 선택하여 기입해 주셔야 합니다.
3. 수신거부 의사표시를 쉽게 할 수 있는 조치 및 방법 표시 의무사항 메시지에 수신의 거부 및 수신동의 철회의 의사표시를 쉽게 할 수 있는 조치 및 방법을 광고 본문에 표기하여 구체적으로 밝혀야 합니다. 동 조치 및 방법으로 수신의 거부 또는 수신동의 철회가 쉽게 이루어지지 않거나 불가능 할 경우에는 이를 표기하지 않는 것으로 간주합니다.
전자우편을 수신 거부하기 위하여 웹사이트에 로그인하도록 하는 등 별도의 추가적인 조치를 거쳐야 하는 것은 수신의 거부 또는 수신동의 철회를 어렵게 하는 것으로 법 위반에 해당합니다.
챗봇 관리자센터 광고성 메시지 전송 정책
챗봇 관리자센터 챗봇을 이용해 Event API를 사용하여 광고성 메시지 발송 시 한국 인터넷 진흥원의 광고표시 가이드에 따라 다음 정책을 지켜야 합니다.
광고성 메시지 전송 정책 광고성 메시지 발송이 가능한 시간은 오전 8시 ~ 오후 8시 50분 입니다. 광고성 메시지는 톡채널과 친구를 맺은 사용자에게만 발송이 가능합니다. 카카오톡 채널 채팅방 상단에 고객센터 연락처를 노출해야 합니다.
위 세 가지 중 한 가지라도 위반하는 경우 Event API 메시지 발송이 실패합니다.
3번 카카오톡 채널 채팅방 상단 고객센터 연락처 설정은 카카오톡 채널 관리자 센터에서 할 수 있으며 방법은 다음과 같습니다.
[채널 > 관리 > 상세설정 > 채널정보 > 고객센터 연락처] 에서 고객센터 연락처를 작성한 뒤 확인 버튼을 눌러 저장합니다.설정이 완료되면 채널 채팅방 내 프로필명 아래에 다음과 같이 고객센터 전화번호가 노출됩니다.
사용자가 알림을 신청을 한 경우에 보내는 정보는 광고성 메시지에 해당되나요?
‘고객의 요청에 의해 발송하는 1회성 정보’의 경우, 영리목적 광고성 정보의 예외 사유에 해당되어 광고표시 가이드 제한 없이 발송할 수 있습니다.
다만, 사용자의 요청이 있었다고 하더라도 1회가 아닌 지속적인 발송은 광고성 정보의 예외 사유에 해당하지 않아 광고표시 가이드를 준수하여 (광고 표시를 하여) 메시지를 전송해야 합니다.
Event API 활용 예시를 살펴보면, 정보성 메시지 예시의 3)재입고 알림 시나리오는 ‘고객의 요청에 의해 발송하는 1회성 정보’에 해당하여 광고표시 가이드 제한 없이 발송이 가능합니다
그러나, 광고성 메시지 예시의 2)관심상품 알림 시나리오의 경우, 1회가 아닌 해당 카테고리에 포함된 제품에 대해 지속적으로 메시지를 발송하는 경우에 해당하여 광고표시 가이드를 준수하여 Event API 메시지를 발송해야 합니다.
챗봇 관리자센터 광고성 메시지 설정 방법
광고성 메시지를 Event API로 전송하기 위해서는 챗봇 관리자센터에서 다음과 같은 설정이 필요합니다.
블록상세 > […] > 이벤트설정
2)이벤트설정>광고성 내용 포함 ON
광고성 내용 포함 설정 팝업 확인
광고성 내용을 포함하는 Event API 메시지는 다음과 같은 말풍선 형태에서만 발송 가능합니다.
광고성 메시지 말풍선 사용 정책
Event API를 사용하여 광고성 메시지를 전송하고자 하는 경우 해당 메시지는 아래 요건을 준수하여야 합니다. Skill응답 생성 시 아래 요건을 만족하지 않는 메시지는 발송되지 않습니다.
광고성 메시지는 말풍선 1개만 포함하여야 합니다.
광고성 메시지로 발송 가능한 말풍선 타입은 아래와 같습니다.
a. 커머스 (CommerceCard)
b. 카드 (BasicCard)
c. 리스트 (ListCard) (단일형만 지원)
d. 아이템형 (itemCard) (스킬 형태로만 지원하는 말풍선입니다)
단일형이 아닌 말풍선을 연속적으로 사용하는 케로셀형 사용 시, 케로셀 헤드가 설정되어야 합니다.
광고성 내용 포함 설정 ON 시, 챗봇 관리자센터에서는 다음과 같이 작성가능한 봇 응답 개수는 3개에서 1개로 변경되며 사용 가능한 말풍선 타입은 카드, 커머스, 리스트, 스킬데이터로 변경됩니다.
광고성 내용 포함 설정이 정상적으로 적용되어 Event API 메시지가 발송되면 다음과 같이 말풍선의 채널명 왼쪽에 (광고)가 노출되며, 말풍선 우측 하단에 수신거부 방법이 표기되어 발송됩니다.
수신거부 방법 표기는 말풍선이 단일형인 경우 해당 말풍선에, 말풍선이 케로셀형인 경우 케로셀헤드에 표기되어 발송됩니다.
Event API 개발 가이드
이벤트 블록 호출 API
앞의 사전설정이 모두 완료되었다면, 이벤트 블록 호출 API를 통해 이벤트 블록을 실행해 카카오톡 채널로 메시지를 전송할 수 있습니다.
Request
POST https://bot-api.kakao.com/v2/bots/{botId}/talk
운영채널로 Event API 발송 시 : botid
개발채널로 Event API 발송 시 : botid!
Request Header
Authorization: KakaoAK {Rest Api Key} Content-Type: application/json
해당 rest api key 는 https://developers.kakao.com 에서 생성한 앱의 앱키 중 REST API 키 로 보내주셔야 합니다.
Request Payload
키 설명 타입 필수여부 event 봇 이벤트 정보 JSON object O user 유저 정보 JSON object O params event param (skill 서버까지 전달) JSON object X option Event API 사용 특수 옵션 JSON object X
1. event (JSON object)
event name은 챗봇 관리자센터 > 블록상세 > 이벤트 설정에 정의한 이름과 동일해야 합니다.
키 설명 타입 필수여부 name 봇 이벤트 정보 string O data 봇 이벤트 Custom parameters JSON(
) X 챗봇 관리자센터의 봇 응답형식 설정(말풍선 설정)에서 event >data 의 파라미터 값을 텍스트 영역에 사용할 수 있습니다. {{#current.event.data.paramName}}을 말풍선에 넣어서 사용할 수 있습니다.
2.user (JSON array of objects)(max.100)
이벤트를 발송할 대상 유저들에 대한 정보입니다. 유저 id 는 중복은 허용되지 않으며, list 의 size max (요청 한번당 최대 발송 건수)는 100개 입니다. 톡채널 정책 상 Event API는 친구관계인 경우에만 메시지를 전송할 수 있으므로, 톡채널과 해당 유저가 친구관계가 아닐 경우 전송은 실패합니다.
유저 아이디 타입은 appUserId (카카오 디벨로퍼스 앱유저 아이디), plusfriendUserKey (skill서버에 전달되는 톡채널 유저 식별값), botUserKey (skill 서버에 전달되는 봇 유저 식별값) 중 하나여야 합니다.
유저 별로 추가적으로 skill 서버에 전달할 데이터가 있을 경우 properties 필드에 담긴 값이 skill payload 의 userRequest.user.properties 필드에 포함되어 전달됩니다.
키 설명 타입 필수여부 type 유저 아이디 타입 (아래 값 중 하나)
– appUserId
– plusfriendUserKey
– botUserKey String O id 유저 아이디 값 String O properties 유저 별 추가 페이로드 JSON(
X 3.params (JSON object)
params의 경우에는 type 에 제한이 없으면 skill server까지 값이 그대로 전달되며, skill 서버에서는 request body 의 userRequest -> params 로 그 값을 전달받을 수 있습니다.
챗봇 관리자센터의 봇 응답형식 설정(말풍선 설정)에서 params 의 파라미터 값을 텍스트 영역에 사용할 수 있습니다. {{#current.params.paramName}}을 말풍선에 넣어서 사용할 수 있습니다.
Request Body Sample
{ “event” : { “name” : “bot_test_event” , “data” : { “text” : “Hello World” } }, “user” : [ { “type” : “botUserKey” , “id” : “12345” }, { “type” : “botUserKey” , “id” : “12346” } ], “params” :{ “foo” : “bar” } }
Response
Response Body
결과가 SUCCESS 가 아닐 경우 아래의 GET API 이벤트 발송 성공여부 조회가 되지 않습니다.
status의 SUCCESS는 ‘요청’에 대한 성공/실패 결과값으로 실제 사용자에게 메시지가 발송되었는지 여부는 아래 이벤트 발송 성공여부 조회 API를 통해 확인할 수 있습니다.
키 설명 타입 필수여부 taskId 해당 리퀘스트에 대한 uuid ( 결과조회를 위한 Id ) String O status one of [“SUCCESS”, “FAIL”, “ERROR”] String O message 상태에 대한 세부 메시지 String X timestamp task 생성 unixtimestamp long O
1.status
STATUS message SUCCESS FAIL ~~~ ERROR ~~~
Request Sample
curl -v -X POST https://bot-api.kakao.com/v2/bots/5b3c85911073e946641ebb6d/talk \ -H ‘Authorization: KakaoAK {kakao developers rest api key}’ \ -H ‘Content-Type: application/json’ \ -d $'{ “event”: { “name”: “home” }, “user”: [ {“type”: “botUserKey”, “id”: “12345”}, {“type”: “botUserKey”, “id”: “12346”} ] }’
※ cURL을 사용하여 개발채널에 이벤트 메시지를 발송하는 경우, {botid!}에 그냥 !만 붙이면 에러가 나기 때문에 다음과 같이 botid 전체를 ‘ ’ 로 감싸줘야 합니다.
POST https://bot-api.kakao.com/v2/bots/’5b3c85911073e946641ebb6d!’/talk
이벤트 발송 성공여부 조회 API
이벤트 발송 결과를 조회하는 API 입니다. 위의 이벤트 블록 호출 API 응답에 있는 status 값이 SUCCESS 일 경우에만 조회가 가능합니다.
Request
GET https://bot-api.kakao.com/v1/tasks/{taskId}
키 설명 타입 필수여부 taskId talk POST 요청 response의 taskId String O
Request Header
Authorization: KakaoAK {Rest Api Key} Content-Type: application/json
해당 rest api key 는 https://developers.kakao.com 에서 생성한 앱의 앱키 중 REST API 키 로 보내주셔야 합니다.
Response
Response Body
POST api 호출 결과가 SUCCESS 가 아닐 경우 결과 조회가 되지 않습니다.
키 설명 타입 필수여부 taskId 실행 결과를 조회하고자 하는 taskId String O status one of [“ALL SUCCESS”, “N FAIL”]
(N: Fail count) String O allRequestCount 전체 요청 횟수
(POST request시 user.ids의 size와 동일) int O successCount 성공적으로 처리된 요청 횟수 int O fail 실패 결과에 대한 정보 JSON Object X(status = “ALL SUCCESS”가 아닌 경우 필수)
1.fail
처리 결과 실패로 끝난 요청에 대한 정보
키 설명 타입 필수여부 count 처리 결과 실패 건 수 int O list 실패 요청에 대한 정보 JSON Object O
2.list
키 설명 타입 필수여부 userId 실패 처리된 userId String O reqUserType 실패 처리된 userId의 종류 String O createdAt 실패 처리된 시각 String O errorMsg 실패 처리된 원인 String O
fail>list>errorMsg 케이스
errorType msg 설명 비고 2 Request user is not a friend of talk channel’s 채널 추가하지 않은 유저 ※ 각 설명에 따라 수정해주세요 (채널추가하지 않은 유저에게는 Event API 메시지 발송이 불가능합니다)
※ 6번 말풍선 제한정책 위반의 경우, 말풍선 도움말 내 제한 및 유의사항을 참고하여 json format을 수정해주세요 6 Invalid skill-json format json format error 혹은 말풍선 정책 위반 99 Invalid parameter format. 주로 json parsing error 104 Skill server returns http error code response. Bot skill server의 에러 응답 ※ 스킬서버 문제일 가능성이 높은 에러 로, 스킬서버 내 이슈가 없는지 먼저 확인해주세요 201 Skill server returns http error code response. Skill server Http 실패 202 Connection to skill server timed out. Skill server 타임아웃 204 Skill server returns http error code response. Block Validation Http 실패 101 Internal server error occured. 봇 내부 통신 에러 ※ 봇 내부 통신 에러일 가능성이 높은 케이스로, 스킬서버 등 이슈가 없는지 확인 후 문의해주세요 102 103 301 501 503 999
월렛 설정하기
우측 상단 계정 레이어 에서 ‘내 월렛’을 선택하여 월렛 화면으로 진입할 수 있습니다. 월렛 화면에서는 월렛을 생성하고 관리할 수 있으며, 월렛을 생성한 사람에게는 자동으로 월렛 마스터 권한이 부여됩니다.
나의 월렛 목록 화면
사업자 월렛 생성하기
Step 1. 월렛 생성 버튼 클릭
내 챗봇 월렛 목록 우측 상단에서 ‘새로운 월렛 생성’ 버튼을 클릭합니다.
Step 2. 유형 선택
월렛 유형 선택시 사업자 월렛을 선택 후 다음 버튼을 클릭합니다.
Step 3. 사업자등록번호 입력
정보입력 단계에서 사업자등록번호를 입력 후 확인 버튼을 클릭합니다.
이미 카카오 서비스에서 비즈니스 채널 인증 등을 통해 비즈니스 정보를 등록한 경우 아래와 같이 조회됩니다.
신규 등록이라면 사업자 이름, 대표자 이름, 업태, 종목, 사업자 주소를 필수로 입력 후 다음 버튼을 클릭합니다.
Step 4. 월렛 이름 입력
원하는 월렛 이름을 입력 후 저장을 클릭해 월렛 생성을 완료합니다.
사업자 월렛으로 생성하는 경우, 아래 기능을 추가로 이용할 수 있습니다.
무통장 입금을 통해 유상캐시를 충전할 수 있습니다.
세금계산서가 발급됩니다.
개인 월렛 생성하기
Step 1. 내 챗봇 월렛 목록 우측 상단의 새로운 월렛 생성버튼 클릭
Step 2. 유형 선택시 ‘개인 월렛’ 선택
Step 3. 본인 확인
‘본인 확인’ 버튼 클릭시 챗봇 관리자센터에 로그인한 카카오 계정을 통해 본인 확인이 자동으로 완료됩니다.
개인정보가 올바르게 입력되어 있는지 확인 후 개인정보 수집 및 이용에 동의합니다. 필수로 동의해야 월렛을 생성할 수 있습니다.
Step 4. 월렛 이름 입력
원하는 월렛 이름을 입력 후 저장을 클릭해 월렛 생성을 완료합니다.
봇과 월렛 연결하기
50,000 건의 무료 사용 구간에서는 월렛 연결 없이도 기존과 동일하게 이용할 수 있으나, 유료 사용 구간 진입시 요금 납부를 위해서 챗봇과 월렛을 필수로 연결해야 합니다. 월렛은 채널 연결과 마찬가지로 봇 설정 메뉴를 통해 연결할 수 있습니다. 설정 메뉴에 추가된 ‘지불 정보’ 탭에서 월렛을 연결하거나 연결된 월렛 정보를 확인할 수 있습니다. 생성된 월렛을 연결하는 방법은 아래와 같습니다.
Step 1. 월렛 연결하기 버튼 클릭
봇 설정 > 지불 정보 탭에서 ‘월렛 연결하기’ 버튼을 클릭합니다.
월렛 미연결 상태라면 월렛 작업 권한을 가진 모든 챗봇 작업자는 본인이 생성한 월렛을 챗봇에 연결할 수 있습니다. 만일, 월렛 작업 권한을 보유하지 않은 작업자는 지불 정보 탭을 확인할 수 없습니다.
Information.
‘새 월렛 만들기’ 버튼을 이용해 나의 월렛 목록을 이동하지 않고도 월렛을 생성할 수 있습니다.
Step 2. 연결할 월렛 선택
연결하고자 하는 월렛을 선택 후 확인 버튼을 클릭합니다. 이때, ‘연결 대기중’ 상태의 월렛만 챗봇에 연결할 수 있습니다.
Step 3. 연결된 월렛 정보 확인
월렛 연결이 완료되었다면, 월렛 작업 권한을 보유한 모든 작업자가 지불 정보 탭에서 연결된 월렛 정보를 확인할 수 있습니다.
월렛 이름, 영업권, 캐시 잔액 클릭시 곧바로 상세 화면에 진입할 수 있습니다.
‘내 챗봇’ 목록에서도 봇과 연결된 월렛 정보를 한 눈에 확인할 수 있습니다.
plusfriend/auto_reply: 플러스친구 자동응답 API
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
챗봇 카카오톡 플러스 친구 챗봇 1:1 코칭 해드립니다. 상품상세
코딩을 잘 모르시는 분들께서도 1:1코칭 시스템으로 궁금하신 내용들 알려드립니다.
큰 돈 지불하고 플러스 친구 코딩 작업 맡기지 마시고, 저렴한 가격으로 이해가 될 때까지 1:1 코칭 시스템으로 원하는 결과물 만들어보세요.
코칭은 팀뷰어 프로그램을 사용하여 원격으로 구매자님 컴퓨터에서 진행될 예정입니다.
또한 음성 전화로 실시간으로 하나하나씩 알려드리면서 수업이 진행 됩니다.
하루만에 원하는 결과물을 만들 수 있도록 도와드리겠습니다.
*”카카오톡 플러스친구 챗봇 만들기 1:1 코칭시스템”을 이런 분 들께 추천 드립니다.*
– 카카오톡을 활용하여 마케팅을 하시는 분.
– 코딩을 할 줄 모르시는 분.
– 빠른 시간 안에 원하는 결과물을 만들고 싶으신 분.
카카오톡 봇 만드는 기본적인 방법 – 90,000원
(기본적인 블록, 버튼 방식의 안내)
버튼을 눌러 지정해둔 답변이 전송, 또는 링크 공유 가능.
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ
이제는 집에서 스스로 원하는 형태의 챗봇을 만들어보세요~
큰 돈 주고 플러스 친구 코딩 작업 맡기는 것 보다 1:1 코칭을 활용하여 원하는 결과물을 만들어서 여러방면으로 마케팅 해보세요!
감사합니다 🙂
음악추천챗봇1. 카카오챗봇 설정
728×90
카카오톡에서 사용할 챗봇을만들기 위해서는 아래와 같은 작업을 진행할 것이다.
1. 카카오 채널 생성
2. 카카오에서 제공해주는 카카오i 오픈빌더 사용신청
3. 챗봇기획
– 시나리오 생성
– 블록작성
– 엔터티 설정
4. 봇을 채널에 연결
카카오채널 생성
카카오채널관리자 센터 바로가기 : https://center-pf.kakao.com/
나는 “오늘의 음악 추천”을 컨셉으로 오.음.추 라는 채널을 생성했다.
카카오 i 오픈빌더?
카카오톡 채널(플러스친구) 프리미어리그봇으로
해당 플러스친구에서 채팅 화면에서 특정 메시지를 입력하면 메시지를 분석해 특정 메시지를 리턴해주는 서비스.
내부 UI는 일반 말풍선만 있는게 아니라 이미지도 있고, 조그만 말풍선 UI도 있다.
나는 뉴스봇이라는 카카오톡 플러스친구를 사용하고 있는데 이게 대표적인 카카오i오픈빌더 UI같다.
이렇게 만들어져 있는 틀을 오픈빌더라는 툴을 활용해서 제작할 수 있는 것이다. .
카카오i 오픈빌더에서 카카오톡 챗봇 만들기 : https://i.kakao.com/
아.. 생각보다 오래걸리는데..? 일단 챗봇연결은 보류하고..
백단에 spotify api와 연동이 되는지 부터 해야겠다.
엄밀히 생각해보면 카카오톡 부분은 fron부분이니까 back부분인 람다부터 구현해야겠다.
카카오 i 오픈빌더 승인완료! 5일이나 걸렸따..
이제 카카오에서 정식으로 봇 서비스를 만들어도 된다고 승인이 난 것이다!!
이제 나만의 카카오톡 챗봇을 만들 수 있다. 카카오톡 채널을 기반으로 한 챗봇이 될 것이다.
챗봇 기획 – 시나리오 생성 / 블록작성 / 엔터티 설정
챗봇에게 예상되는 사용자의 발화패턴을 미리 사전에 정의해두는 작업이다.
시나리오 생성
챗봇 시나리오는 사용자가 입력한 내용에 따라 특정 메세지를 리턴하도록 설정하는 것이다.
즉, 사용자가 챗봇을 통해 경험할 수 있는 서비스를 의미한다.
어떤 인풋을 받을떄, 어떤 아웃풋을 어떻게 표현할 것인지 직접 구성하고 디자인하는 과정이라고 보면 된다.
블록 작성
시나리오를 위해서는 블록을 작성해야한다.
블록은 사용자의 의도를 응대하는 가장 작은 단위를 의미한다.
하나의 상황이라고 보면 될 것 같다.
즉, 다양한 블록이 모여 하나의 시나리오를 구성하는 것이다.
웰컴블록 : 봇이 사용자를 처음 만날때 발송하는 환영메세지
폴백블록 : 봇이 사용자의 의도를 이해하지 못할때 응답하는 메세지
탈출블록 : 사용자가 대화를 초기화하거나 탈출하고 싶을때 쓰는 사용자 명령어
커스텀블록 : 이외에 블록을 추가하여 기본시나리오 외에 커스텀 시나리오를 구성할 수 있다
단, 시나리오와 블록은 미리 철저하게 설계를 하고 진행해야한다.
블록을 수정하고 학습하기 위해 머신러닝 실행버튼을 실행해야하는데 이 학습이 최소 10분이 소요되기 때문.
빈번하게 수정이 어렵다는 이야기!
나의 경우, 아티스트명을 검색어로 받기 때문에 사용자 발화에 해당하는 패턴발화는 아래와 같다.
엔터티 설정
언터티는 봇이 이해할 수 있는 용어를 체계적으로 정리한 데이터 사전을 말한다.
엔티티가 정의되어 있다면, 봇은 사용자가 입력한 발화가 어떤 의도인지 어떤 동작을 해야하는지 데이터를 추출 가능
나의 엔터티 : 작업자가 직접 정의
시스템 엔터티 : 자주 사용하는 엔티티를 미리 정의
봇을 생성한 직후에는 시스템 엔터티만 있기 때문에 알아들을 수 있는 용어가 제한적일 수 있다
그래서 봇의 특성에 맞도록 엔터티를 잘 설계해야한다고 한다.
하지만 나의 경우 아티스트를 검색하기 떄문에, 해당 아티스트가 사람이름이거나 그룹이라는 시스템엔터티만 추가했다
엔터티 매핑
이제 각 발화에 엔터티를 매핑해야한다.
사용자가 입력한 값(아티스트)가 어떤 엔터티에 속하는지를 지정해주면
카카오톡을 보낼떄 파라미터로 보낼 수 있는 것이다. 즉, 이 파라미터 값으로 코드에서 전달할듯?!?
이렇게 각 발화패턴을 더블클릭해서 엔터티를 일일이 찾아 선택해줘야한다. 그럼 발화명이 블록으로 바뀐다.
위에서 엔터티로 name이랑 group을 지정했다.
그래서 대표적인 그룹으로 방탄소년단과, 대표적인 name에 해당하는 아이유를 등록해봤다.
그럼 이렇게 챗봇입장에선 입력받은 아티스트명을 파라미터로 인식할 수 있게 된다.
파라미터 설정
아티스트명을 파라미터로 받을때는
아래와 같은 파라미터 변수($sys_person_group, $sys_person_name)으로 인식하게 된다.
이 변수명에 따라서 코드를 짤때 받으면 될 것 같은데 약간 이름을 변형하도록 하자.
사용자 패턴 발화 입력
광기로…국내외 아티스트에 해당하는 사용자발화를 70개정도 입력했다…
너무 많을것 같아서 약간의 제약사항을 두었다.
검색어 입력은 띄어쓰기를 포함하면 안된다.
영어로검색하는 경우 소문자로만 검색해야한다.
그리고 약어(?)도 가능하다. (ex : 방탄소년단-방탄, 빌리아일리시-빌리)
봇 응답 입력
위에서 설정한 예상된 아티스트명이 검색이 되었을때 봇이 어떻게 응답할지도 설정해준다.
나는 카드형을 선택했다. 나중에 바뀔수도 있껬지만..
이미지 주소는 스포티파이에서 주는 image URL주소를 넣고,,
설명과 타이틀은 아티스트명과 앨범을 나타내면 되려나?
그리고 응답테스트를 해보았다.
단, 응답테스트는 2개이상의 시나리오가 작성이 되어야하고, 사용자발화가 최소20개 작성되어야한다.
월컴블록과 시나리오01을 완료하고 봇테스트를 해보았다.
봇을 채널에 연결
마지막으로 이렇게 기획한 챗봇을 카카오톡에서 사용하기 위한 채널이 필요하다.
그래서 앞서 만든 채널에 봇을 연결해야한다.
마무리
카카오i빌더로 기획하고 구성하는 부분은 약간 프론트단 작업같았다.
이제 앞단에 어떻게 사용자아게 보여지는지를 상상해보았으니 이걸 뒤에 api와 연결을 잘 해보자! 이게 백단부분!
출처
카카오i빌더 레퍼런스 : https://i.kakao.com/docs/key-concepts-entity#%EC%97%94%ED%8B%B0%ED%8B%B0%EC%9D%98-%EC%A2%85%EB%A5%98
카카오i 빌더 사용사례 : https://vmpo.tistory.com/59?category=733430
카카오i 빌더 익히기 : https://luckygg.tistory.com/293
반응형
전문 카카오톡 플러스친구 스토리 챗봇 제작해 드립니다.
서비스 설명
신속·정확 [12년 경력] 마케터 스낵컬처입니다.
솔루션 컨설팅, 브랜드 바이럴 마케팅, 쇼핑몰 운영 및 상품 콘텐츠 촬영이 주 메인이며 깊이가 있는 모니터링과 꼼꼼하며 섬세한 작업으로 클라이언트와 함께 합니다.
ㅇ 플러스친구 기본세팅 : https://kmong.com/gig/178979
세팅 상세 내용
–
– 카카오톡 플러스 친구 챗봇(자동응답)만 진행합니다.
– 작업자의 오픈빌더로 작업으로 진행합니다.
– 필수 작업내용은 인터뷰에 전달받은 자료의 기준으로만 진행됩니다.
– 최종 인터뷰 완료 후 초반 작업이 완료되면, 중간 진행 사항을 전달드립니다.
– 필요에 따라 대화 박스의 UI/UX가 수정될 수 있습니다.
– 글자 수, 이미지 사이즈에 따라 수정될 수 있습니다.
– 이미지 경우, 의뢰인 측에서 파일을 제공해 주시기 바랍니다.
(이미지가 없을 시, 추가 비용이 발생될 수 있습니다)
※ 실제 작업 세팅 및 등록은 2~7일 이내 완료됩니다.
※ 인터뷰 진행 및 피드백이 늦어지면 등록 완료가 지연될 수 있습니다.
※ 작업 기간은 최대 30일 기준으로 완료됩니다.
(기간이 길어질 경우, 추가 비용이 발생될 수 있습니다.)
키워드에 대한 정보 플러스 친구 챗봇
다음은 Bing에서 플러스 친구 챗봇 주제에 대한 검색 결과입니다. 필요한 경우 더 읽을 수 있습니다.
이 기사는 인터넷의 다양한 출처에서 편집되었습니다. 이 기사가 유용했기를 바랍니다. 이 기사가 유용하다고 생각되면 공유하십시오. 매우 감사합니다!
사람들이 주제에 대해 자주 검색하는 키워드 카카오톡 챗봇 만들기 -1.사전준비
- #쳇봇
- 챗봇
- 쳇봇
- 카카오챗봇
카카오톡 #챗봇 #만들기 #-1.사전준비
YouTube에서 플러스 친구 챗봇 주제의 다른 동영상 보기
주제에 대한 기사를 시청해 주셔서 감사합니다 카카오톡 챗봇 만들기 -1.사전준비 | 플러스 친구 챗봇, 이 기사가 유용하다고 생각되면 공유하십시오, 매우 감사합니다.