POPBill Developers
가이드

튜토리얼

Delphi 개발환경에서 팝빌 SDK를 추가하여 카카오톡 알림톡 전송 (SendATS) 함수를 구현하는 예시입니다.

1. POPBiLL SDK 추가

팝빌 연동자료실에서 Delphi SDK 예제코드 다운로드 후 압축을 해제합니다.

압축해제한 SDK 예제코드에서 Linkhub/ Popbill/ PopbillTaxinvoice/ 각 폴더의 pas파일 3개를 프로젝트 유닛으로 추가합니다.

2. POPBiLL SDK 설정

아래 코드를 참조하여 Form 파일을 수정합니다.

  1. ① use 참조유닛 추가
  2. ② 인증정보 변수와 서비스 클래스를 선언
  3. ③ FormCreate 프로시저에 카카오톡 서비스 클래스 인스턴스 생성 및 초기화
unit Example;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  StdCtrls, TypInfo, shellapi, ExtCtrls, Grids,
  Popbill, PopbillKakao;

const
  // 링크아이디
  LinkID = 'TESTER';

  // 비밀키
  SecretKey = 'SwWxqU+0TErBXy/9TVjIPEnI0VTUMMSQZtJf3Ed8q3I=';
// 생략
// ...
// ...

var
  // 카카오톡 서비스 객체 선언
  kakaoService : TKakaoService;
// 생략
// ...
// ...

procedure TfrmExample.FormCreate(Sender: TObject);
begin
  // 카카오톡 서비스 객체 초기화
  kakaoService := TKakaoService.Create(LinkID,SecretKey);

  // 연동환경 설정, true-테스트, false-운영(Production), (기본값:false)
  kakaoService.IsTest := true;

  // 인증토큰 IP 검증 설정, true-사용, false-미사용, (기본값:true)
  kakaoService.IPRestrictOnOff := true;

  // 예외 처리 설정, true-사용, false-미사용, (기본값:true)
  kakaoService.IsThrowException := true;

  // 로컬시스템 시간 사용여부, true-사용, false-미사용, (기본값:false)
  kakaoService.UseLocalTimeYN := false;
end;

3. SendATS 기능 구현

Form에 버튼을 생성하고 버튼의 Click Event 코드에 카카오톡 알림톡 전송 (SendATS) 함수를 추가합니다.

procedure TfrmExample.btnSendATS_oneClick(Sender: TObject);
var
    receiptNum, templateCode, senderNum, altSendType, receiverNum,
    receiverName, content, altContent, requestNum : String;
    Buttons : TSendKakaoButtonList;
    reserveDT : String;
    corpNum : String;
    userID : String;
begin

    // 팝빌회원 사업자번호
    corpNum := '1234567890';

    // 팝빌회원 아이디
    userID := 'testkorea';

    // 알림톡 템플릿코드, ListATSTemplate 함수 반환항목중 templateCode로 확인
    // GetATSTemplateMgtURL(알림톡 템플릿 관리 팝업) 함수를 통해서 확인
    templateCode := '018110000047';

    // 팝빌에 사전 등록된 발신번호
    senderNum := '070-4304-2991';

    // 수신번호
    receiverNum := '010111222';

    // 수신자명
    receiverName := '수신자명';

    // 알림톡 메시지 내용 (최대 1000자)
    // 템플릿의 내용과 일치하지 않은 경우 전송실패
    content := '테스트 알림톡';

    // 대체문자 내용  (최대 2000byte)
    altContent := '대체문자 내용';

    // 대체문자 전송유형, 공백-미전송, C-알림톡전송, A-대체문자 전송
    altSendType := 'A';

    // 알림톡 버튼정보를 템플릿 신청시 기재한 버튼정보와 동일하게 전송하는경우 길이를 0으로 처리
    SetLength(Buttons, 0);

    // 알림톡 버튼 URL에 #{템플릿변수}를 기재한 경우 버튼정보추가 - 템플릿 변수만 변경하여 구성
    //SetLength(Buttons, 1);
    //Buttons[0] := TSendKakaoButton.Create;
    //Buttons[0].buttonName := '버튼명'; // 버튼명
    //Buttons[0].buttonType := 'WL';     // 버튼 DS-배송조회 WL-웹링크 AL-앱링크 MD-메시지전달 BK-봇키워드
    //Buttons[0].buttonURL1 := 'http://www.weblink1.com'; // 버튼링크1  [앱링크] Android / [웹링크] Mobile
    //Buttons[0].buttonURL2 := 'http://www.weblink2.com'; // 버튼링크2  [앱링크] IOS / [웹링크] PC URL

    // 요청번호
    // 파트너가 전송 건에 대해 관리번호를 구성하여 관리하는 경우 사용.
    // 1~36자리로 구성. 영문, 숫자, 하이픈(-), 언더바(_)를 조합하여 팝빌 회원별로 중복되지 않도록 할당.
    requestNum := '';

    // 예약전송일시
    reserveDT := '';

    try
            receiptNum := kakaoService.SendATS(corpNum, templateCode, senderNum, altSendType,
                                                reserveDT, receiverNum, receiverName, content,
                                                altContent, Buttons, userID, requestNum);
    except
            on le : EPopbillException do begin
                    ShowMessage('응답코드 : ' + IntToStr(le.code) + #10#13 +'응답메시지 : '+ le.Message);
                    Exit;
            end;
    end;

    if kakaoService.LastErrCode <> 0 then
    begin
            ShowMessage('응답코드 : ' + IntToStr(kakaoService.LastErrCode) + #10#13 +'응답메시지 : '+ kakaoService.LastErrMessage);
    end
    else
    begin
            txtReceiptNum.Text := receiptNum;
            ShowMessage('접수번호 (receiptNum) : ' + receiptNum);
    end;
end;

4. 결과 확인

함수 호출 반환 결과는 아래와 같습니다.
- 성공 : Response code 로 숫자 1 반환
- 실패 : PopbillException 으로 음의 정수 8자리 숫자값 오류코드와 오류메시지 반환 [오류코드]