POPBill Developers
연동신청
  • 가이드 0
  • 레퍼런스 0
  • 오류코드 0
현금영수증
  • 전자세금계산서
  • 현금영수증
  • 전자명세서
  • 홈택스수집(세금)
  • 홈택스수집(현금)
  • 사업자등록상태조회
  • 기업정보조회
  • 계좌조회
  • 예금주조회
  • 카카오톡
  • 문자
  • 팩스
Node.js
  • Java
  • PHP
  • .NET
  • .NET Core
  • Node.js
  • Python
  • Ruby
  • ASP
  • Delphi
  • PowerBuilder
  • Visual Basic
  • MS Access
SDK 레퍼런스

튜토리얼

Node.js 개발환경에서 팝빌 SDK를 추가하고, 현금영수증 즉시 발행 (RegistIssue) API를 호출하는 기본 과정을 단계별로 따라 해볼 수 있도록 구성된 가이드 입니다.

1. POPBiLL SDK 추가

팝빌 Node.js SDK를 추가하기 위해 Express 프로젝트 "package.json" 파일에 팝빌 Node.js SDK 정보를 추가하고 npm install 또는 npm update를 진행합니다.

{
  "name": "Popbill TEST",
  "version": "0.0.0",
  "private": true,
  "scripts": {
    "start": "node ./bin/www"
  },
  "dependencies": {
    "cookie-parser": "~1.4.3",
    "debug": "~2.6.9",
    "ejs": "~2.5.7",
    "express": "~4.16.0",
    "http-errors": "~1.6.2",
    "morgan": "~1.9.0",
    "popbill": "^1.63.0"
  }
}

2. POPBiLL SDK 설정

프로젝트 routes 폴더 하위의 index.js 파일에 연동신청시 발급받은 API Key 를 변수로 선언하고 아래의 코드를 참조하여 현금영수증 서비스 객체를 생성 합니다.

// 생략..

var popbill = require('popbill');

popbill.config( {

  // 링크아이디
  LinkID :'TESTER',

  // 비밀키
  SecretKey : 'SwWxqU+0TErBXy/9TVjIPEnI0VTUMMSQZtJf3Ed8q3T=',

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

  // 통신 IP 고정, true-사용, false-미사용, (기본값:true)
  IPRestrictOnOff: true,

  // 팝빌 API 서비스 고정 IP 사용여부, 기본값(false)
  UseStaticIP: false,

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

  defaultErrorHandler: function (Error) {
    console.log('Error Occur : [' + Error.code + '] ' + Error.message);
  }

});

// 현금영수증 서비스 객체 초기화
var cashbillService = popbill.CashbillService();

// 생략..

3. RegistIssue 기능 구현

index.js 파일에 현금영수증 즉시 발행 (RegistIssue) 함수 호출 코드를 추가합니다.

router.get('/registIssue', function (req, res, next) {

    // 팝빌회원 사업자번호, '-' 제외 10자리
    var testCorpNum = '1234567890';

    // 문서번호
    // 문서 관리를 위해 파트너가 할당하는 식별번호
    // 1~24자리 영문 대소문자, 숫자, 특수문자('-','_')로 구성
    var MgtKey = '20250314-001';

    // 현금영수증 상태 이력을 관리하기 위한 메모
    var stateMemo = "발행메모";

    // 현금영수증 객체 생성
    var cashbill = {

        mgtKey: MgtKey,

        // 거래일시, 형식(yyyyMMddHHmmss)
        // 발행기준 전일부터 당일까지 입력 가능
        // 미입력시 기본값(발행일시) 처리됨
        tradeDT: "20250319093919",

        // 문서형태
        tradeType: '승인거래',

        // 과세형태, [과세, 비과세] 중 기재
        taxationType: '과세',

        // 거래구분, [소득공제용, 지출증빙용] 중 기재
        tradeUsage: '소득공제용',

        // 거래유형, [일반, 도서공연, 대중교통] 중 기재
        tradeOpt: '일반',

        // 공급가액
        supplyCost: '10000',

        // 부가세
        tax: '1000',

        // 봉사료
        serviceFee: '0',

        // 합계금액, 공급가액 + 부가세 + 봉사료
        totalAmount: '11000',

        // 가맹점 사업자번호, "-" 제외 10자리
        franchiseCorpNum: testCorpNum,

        // 가맹점 종사업장 식별번호
        franchiseTaxRegID: '',

        // 가맹점 상호
        franchiseCorpName: '가맹점 상호',

        // 가맹점 대표자성명
        franchiseCEOName: '가맹점 대표자 성명',

        // 가맹점 주소
        franchiseAddr: '가맹점 주소',

        // 가맹점 전화번호
        franchiseTEL: '01012341234',

        // 식별번호, 거래구분에 따라 작성
        // 소득공제용 - 주민등록/휴대폰/카드번호/자진발급용 번호(010-000-1234) 기재가능
        // 지출증빙용 - 사업자번호/주민등록/휴대폰/카드번호 기재가능
        identityNum: '0101112222',

        // 주문 상품명
        itemName: '상품명',

        // 주문번호
        orderNumber: '주문번호',

        // 구매자(고객) 성명
        customerName: '고객명',

        // 구매자(고객) 이메일
        // 팝빌 개발환경에서 테스트하는 경우에도 안내 메일이 전송되므로,
        // 실제 구매자의 메일주소가 기재되지 않도록 주의
        email: 'test@test.com',

        // 구매자(고객) 휴대폰
        hp: '010111222',

        // 구매자 알림문자 전송 여부
        // 알림문자 전송시 포인트가 차감되며, 전송실패시 환불처리됨
        smssendYN: false
    };

    cashbillService.registIssue(testCorpNum, cashbill, stateMemo,
        function (result) {
            res.render('response', {path: req.path, code: result.code, message: result.message});
        }, function (Error) {
            res.render('response', {path: req.path, code: Error.code, message: Error.message});
        });
});

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

<!DOCTYPE html>
<!DOCTYPE html>
<html>
<head>
    <title>Popbill Cashbill</title>
</head>
<body>
<div>
    <p>Response</p>
    <br/>
    <fieldset>
        <ul>
            <li>응답코드 (Response.code) : <%= code %></li>
            <li>응답메시지 (Response.message) : <%= message %></li>
        </ul>
    </fieldset>
</div>
</body>
</html>

4. API 응답결과 확인

API 호출 응답결과는 다음과 같습니다.

구분 응답
성공 code : 1
실패 code : 오류코드 (8자리 음의 정수) [오류코드]
message : 오류메시지