[Python - Django] 팝빌 현금영수증 SDK 튜토리얼

Django 프레임워크를 사용하는 환경에서 pip를 이용해 팝빌 Python SDK를 추가한 후 현금영수증 즉시발행(RegistIssue) SDK 함수를 구현하는 예시입니다. 팝빌 Python SDK Django Example

1. Popbill SDK 추가

① 팝빌 Python SDK를 추가하기 위해 pip install 명령어를 사용하여 패키지를 설치합니다.

$ pip install popbill

② Django 프로젝트의 config/settings.py 파일에 연동신청시 발급받은 인증정보와 연동환경 설정값을 선언합니다.

연동신청시 발급받은 인증정보로 링크아이디(LinkID)와 비밀키(SecretKey) 값을 변경하시기 바랍니다.

# -*- coding: utf-8 -*-
import os
import sys
imp.reload(sys)

try:
    sys.setdefaultencoding('UTF8')
except Exception as E:
    pass

#생략
#...
#...

# 링크아이디
LinkID = "TESTER"

# 발급받은 비밀키, 유출에 주의하시기 바랍니다.
SecretKey = "SwWxqU+0TErBXy/9TVjIPEnI0VTUMMSQZtJf3Ed8q3I="

# 연동환경 설정값, 개발용(True), 상업용(False)
IsTest = True

2. API 구현

① Django App에 생성된 views.py 파일에 현금영수증 서비스 클래스 객체 생성과 현금영수증 즉시발행(RegistIssue API) 함수 호출 코드를 추가합니다.


# -*- coding: utf-8 -*-
from django.shortcuts import render
from popbill import CashbillService, PopbillException, Cashbill, ContactInfo, CorpInfo, JoinForm

from config import settings

# config/settings.py 작성한 LinkID, SecretKey를 이용해 CashbillService 객체 생성
cashbillService = CashbillService(settings.LinkID, settings.SecretKey)

# 연동환경 설정값, 개발용(True), 상업용(False)
cashbillService.IsTest = settings.IsTest

def registIssue(request):
    try:
        # 팝빌회원 사업자번호
        CorpNum = "1234567890"

        # 팝빌회원 아이디
        UserID = "testkorea"

        # 즉시발행 메모
        Memo = "현금영수증 즉시발행 메모"

        # 현금영수증 정보
        cashbill = Cashbill(

            # [필수] 문서관리번호, 1~24자리, (영문,숫자,'-','_') 조합으로 사업자별 고유번호 생성
            mgtKey="20190830-001",

            # [필수] 문서형태, [승인거래 / 취소거래]
            tradeType="승인거래",

            # [취소거래시 필수] 원본 현금영수증 국세청승인번호
            orgConfirmNum="",

            # [취소거래시 필수] 원본 현금영수증 거래일자
            orgTradeDate="",

            # [필수] 과세형태, [과세 / 비과세]
            taxationType="과세",

            # [필수] 거래유형, [일반 / 도서공연 / 대중교통]
            tradeOpt="일반",

            # [필수] 거래구분, [소득공제용 /지출증빙용]
            tradeUsage="소득공제용",

            # [필수] 거래처 식별번호
            # 거래유형이 '지출증빙용' - [휴대폰/카드/주민등록/사업자] 번호 입력
            # 거래유형이 '소득공제용' - [휴대폰/카드/주민등록] 번호 입력
            # 자진발급 "010-000-1234" 의 경우 "소득공제용"으로만 발급 가능
            identityNum="010-000-1234",

            # [필수] 공급가액
            supplyCost="10000",

            # [필수] 세액
            tax="1000",

            # 봉사료
            serviceFee="0",

            # [필수] 거래금액, 공급가액+세액+봉사료
            totalAmount="11000",

            # 발행자 사업자번호
            franchiseCorpNum=CorpNum,

            # 발행자 상호
            franchiseCorpName="발행자 상호",

            # 발행자 대표자성명
            franchiseCEOName="발행 대표자 성명",

            # 발행자 주소
            franchiseAddr="발행자 주소",

            # 발행자 연락처
            franchiseTEL="07012345678",

            # 주문자명
            customerName="주문자명",

            # 주문상품명
            itemName="주문상품명",

            # 주문번호
            orderNumber="주문번호",

            # 이메일
            email="test@test.com",

            # 휴대폰
            hp="010111222",

            # 발행안내문자 전송여부
            smssendYN=False
        )

        response = cashbillService.registIssue(CorpNum, cashbill, Memo, UserID)

        return render(request, 'response.html', {'code': response.code, 'message': response.message})
    except PopbillException as PE:
        return render(request, 'exception.html', {'code': PE.code, 'message': PE.message})

② 함수 호출결과 코드와 메시지를 출력하는 "/response.html" 파일을 추가합니다.

<html xmlns=" http://www.w3.org/1999/xhtml ">
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Popbill API Test.</title>
  </head>
  <body>
    <div id="content">
        <p class="heading1">Response</p>
        <br/>
        <fieldset class="fieldset1">
            <ul>
                <li>응답코드 (Response.code) : {{ code }}</li>
                <li>응답메시지 (Response.message) : {{ message }}</li>
            </ul>
        </fieldset>
    </div>
  </body>
</html> 

③ 웹브라우저에서 페이지를 호출하여 함수호출 결과를 확인합니다.

팝빌 Python SDK 현금영수증 Example

기술지원센터

팝빌 기술지원은 유선, 메일, 원격지원 등 다양한 채널을 통해 제공됩니다.

T. 1600-9854   E. code@linkhub.co.kr

연동문의