[Node.js] 팝빌 전자세금계산서 SDK 튜토리얼

Express 개발환경에서 NPM을 이용해 팝빌 Node.js SDK를 추가한 후 전자세금계산서 즉시발행(RegistIssue) SDK 함수를 구현하는 예시입니다. 팝빌 Node SDK Express Example

1. NPM Popbill SDK 추가

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

{
  "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.12.1"
  }
}

② routes/index.js 파일에 연동신청시 발급받은 인증정보를 변수로 선언하고 아래의 코드를 참조하여 전자세금계산서 서비스 객체를 생성 합니다.

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

var popbill = require('popbill');

popbill.config( {

    // 링크허브에서 발급받은 링크아이디, 비밀키
    LinkID :'LinkID',
    SecretKey : 'SwWxqU+0TExEXy/9TVjKPExI2VTUMMSLZtJf3Ed8q3I=',

    // 연동환경 설정값, (true-개발용, false-상업용)
    IsTest : true

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

});

var taxinvoiceService = popbill.TaxinvoiceService();

2. API 구현

① index.js 파일에 전자세금계산서 즉시발행(RegistIssue API) 함수 호출 코드를 추가합니다.


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

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

    // 문서관리번호, 1~24자리 영문,숫자,'-','_' 조합으로 사업자별로 중복되지 않도록 구성
    var mgtKey = '20190829-032';

    // 세금계산서 항목
    var Taxinvoice = {

        // [필수] 작성일자, 날짜형식 yyyyMMdd
        writeDate: '20190829',

        // [필수] 과금방향, (정과금, 역과금) 중 기재, 역과금은 역발행의 경우만 가능
        chargeDirection: '정과금',

        // [필수] 발행형태, (정발행, 역발행, 위수탁) 중 기재
        issueType: '정발행',

        // [필수] (영수, 청구) 중 기재
        purposeType: '영수',

        // [필수] 발행시점, (직접발행, 승인시자동발행) 중 기재
        issueTiming: '직접발행',

        // [필수] 과세형태, (과세, 영세, 면세) 중 기재
        taxType: '과세',


        /************************************************************************
         *                              공급자 정보
         **************************************************************************/

        // [필수] 공급자 사업자번호, '-' 제외 10자리
        invoicerCorpNum: testCorpNum,

        // [정발행시 필수] 문서관리번호, 1~24자리 숫자,영문,'-','_' 조합으로 사업자별로 중복되지 않도록 구성
        invoicerMgtKey: mgtKey,

        // 공급자 종사업장 식별번호, 필요시 기재, 4자리 숫자
        invoicerTaxRegID: '',

        // [필수] 공급자 상호
        invoicerCorpName: '공급자 상호',

        // [필수] 대표자 성명
        invoicerCEOName: '대표자 성명',

        // 공급자 주소
        invoicerAddr: '공급자 주소',

        // 공급자 종목
        invoicerBizClass: '공급자 업종',

        // 공급자 업태
        invoicerBizType: '공급자 업태',

        // 공급자 담당자명
        invoicerContactName: '공급자 담당자명',

        // 공급자 연락처
        invoicerTEL: '070-4304-2991',

        // 공급자 휴대폰번호
        invoicerHP: '010-000-111',

        // 공급자 메일주소
        invoicerEmail: 'test@test.com',

        // 정발행시 알림문자 전송여부
        // - 문자전송지 포인트가 차감되며, 전송실패시 포인트 환불처리됩니다.
        invoicerSMSSendYN: false,


        /************************************************************************
         *                           공급받는자 정보
         **************************************************************************/

        // [필수] 공급받는자 구분, (사업자, 개인, 외국인) 중 기재
        invoiceeType: '사업자',

        // [필수] 공급받는자 사업자번호, '-'제외 10자리
        invoiceeCorpNum: '8888888888',

        // [역발행시 필수] 공급받는자 문서관리번호
        invoiceeMgtKey: '',

        // 공급받는자 종사업장 식별번호, 필요시 기재, 4자리 숫자
        invoiceeTaxRegID: '',

        // [필수] 공급받는자 상호
        invoiceeCorpName: '공급받는자 상호',

        // [필수] 공급받는자 대표자 성명
        invoiceeCEOName: '공급받는자 대표자 성명',

        // 공급받는자 주소
        invoiceeAddr: '공급받는자 주소',

        // 공급받는자 종목
        invoiceeBizClass: '공급받는자 종목',

        // 공급받는자 업태
        invoiceeBizType: '공급받는자 업태',

        // 공급받는자 담당자명
        invoiceeContactName1: '공급받는자 담당자명',

        // 공급받는자 연락처
        invoiceeTEL1: '010-111-222',

        // 공급받는자 휴대폰번호
        invoiceeHP1: '070-111-222',

        // 공급받는자 이메일 주소
        invoiceeEmail1: 'test2@test.com',

        // 역발행시 알림문자 전송여부
        // - 문자전송지 포인트가 차감되며, 전송실패시 포인트 환불처리됩니다.
        invoiceeSMSSendYN: false,


        /************************************************************************
         *                           세금계산서 기재정보
         **************************************************************************/

        // [필수] 공급가액 합계
        supplyCostTotal: '10000',

        // [필수] 세액합계
        taxTotal: '1000',

        // [필수] 합계금액 (공급가액 합계 + 세액 합계)
        totalAmount: '11000',

        // 기재 상 '일련번호'' 항목
        serialNum: '123',

        // 기재 상 '현금'' 항목
        cash: '',

        // 기재 상 '수표' 항목
        chkBill: '',

        // 기재 상 '어음' 항목
        note: '',

        // 기재 상 '외상' 항목
        credit: '',

        // 기재 상 '비고' 항목
        remark1: '비고',
        remark2: '비고2',
        remark3: '비고3',

        // 기재 상 '권' 항목, 최대값 32767
        kwon: '',

        // 기재 상 '호' 항목, 최대값 32767
        ho: '',

        // 사업자등록증 이미지 첨부여부
        businessLicenseYN: false,

        // 통장사본 이미지 첨부여부
        bankBookYN: false,


        /************************************************************************
         *                           상세항목(품목) 정보
         **************************************************************************/

        detailList: [
            {
                serialNum: 1,                // 일련번호, 1부터 순차기재
                purchaseDT: '20190829',      // 거래일자, 형식 : yyyyMMdd
                itemName: '품명1',
                spec: '규격',
                qty: '1',                    // 수량, 소수점 2자리까지 기재 가능
                unitCost: '5000',           // 단가, 소수점 2자리까지 기재 가능
                supplyCost: '5000',         // 공급가액, 소수점 기재불가, 원단위 이하는 절사하여 표현
                tax: '500',                 // 세액, 소수점 기재불가, 원단위 이하는 절사하여 표현
                remark: '비고'
            },
            {
                serialNum: 2,                // 일련번호, 1부터 순차기재
                purchaseDT: '20190829',      // 거래일자, 형식 : yyyyMMdd
                itemName: '품명2',
                spec: '규격',
                qty: '1',                    // 수량, 소수점 2자리까지 기재 가능
                unitCost: '5000',           // 단가, 소수점 2자리까지 기재 가능
                supplyCost: '5000',         // 공급가액, 소수점 기재불가, 원단위 이하는 절사하여 표현
                tax: '500',                 // 세액, 소수점 기재불가, 원단위 이하는 절사하여 표현
                remark: '비고'
            }
        ],


        /************************************************************************
         *                         수정세금계산서 기재정보
         * - 수정세금계산서를 작성하는 경우에만 값을 기재합니다.
         * - 수정세금계산서 관련 정보는 연동매뉴얼 또는 개발가이드 링크 참조
         * - [참고] 수정세금계산서 작성방법 안내 - http://blog.linkhub.co.kr/650
         **************************************************************************/

        // [수정세금계산서 발행시 필수] 수정사유코드, 수정사유에 따라 1~6 숫자 기재
        modifyCode: '',

        // [수정세금계산서 발행시 필수] 원본세금계산서 ItemKey
        // - 문서정보확인 (GetInfo API)의 응답결과(ItemKey 항목) 확인
        originalTaxinvoiceKey: '',


        /************************************************************************
         *                             추가담당자 정보
         * - 세금계산서 발행안내 메일을 수신받을 공급받는자 담당자가 다수인 경우
         * 추가 담당자 정보를 등록하여 발행안내메일을 다수에게 전송할 수 있습니다. (최대 5명)
         **************************************************************************/

        // 추가담당자 정보
        addContactList: [
            {
                // 일련번호, 1부터 순차기재
                serialNum: 1,

                // 담당자명
                contactName: '담당자 성명',

                // 담당자 메일
                email: 'test2@test.com'
            },
            {
                // 일련번호, 1부터 순차기재
                serialNum: 2,

                // 담당자명
                contactName: '담당자 성명 2',

                // 담당자 메일
                email: 'test3@test.com'
            }
        ]
    };

    taxinvoiceService.registIssue(testCorpNum, Taxinvoice,
        function (result) {
            res.render('response', {path: req.path, code: result.code, message: result.message, ntsConfirmNum: result.ntsConfirmNum});
        }, function (Error) {
            res.render('response', {path: req.path, code: Error.code, message: Error.message});
        });
});

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


<!DOCTYPE html>
<html>
<head>
    <title>Popbill Taxinvoice</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>
            <% if (typeof ntsConfirmNum  != 'undefined') { %>
              <li>국세청승인번호 (Response.ntsConfirmNum) : <%= ntsConfirmNum %></li>
            <% } %>
        </ul>
    </fieldset>
</div>
</body>
</html>

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

팝빌 NodeJS SDK 전자세금계산서 Example

기술지원센터

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

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

연동문의