[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 statementService = popbill.StatementService();

2. API 구현

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


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

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

    // 명세서 코드 - 121(거래명세서), 122(청구서), 123(견적서), 124(발주서), 125(입금표), 126(영수증)
    var ItemCode = 121;

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


    // 전자명세서 정보
    var statement = {

        // [필수] 기재상 작성일자, 날짜형식(yyyyMMdd)
        writeDate: '20190829',

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

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

        // 맞춤양식코드, 미기재시 기본양식으로 작성
        formCode: '',

        // [필수] 명세서 코드
        itemCode: ItemCode,

        // [필수] 문서관리번호
        mgtKey: MgtKey,

        /*************************************************************************
         *                             발신자 정보
         **************************************************************************/

        // 발신자 사업자번호
        senderCorpNum: testCorpNum,

        // 발신자 상호
        senderCorpName: '발신자 상호',

        // 발신자 주소
        senderAddr: '발신자 주소',

        // 발신자 대표자 성명
        senderCEOName: '발신자 대표자 성명',

        // 종사업장 식별번호, 필요시기재, 형식은 숫자 4자리
        senderTaxRegID: '',

        // 발신자 종목
        senderBizClass: '종목',

        // 발신자 업태
        senderBizType: '업태',

        // 발신자 담당자명
        senderContactName: '담당자명',

        // 발신자 메일주소
        senderEmail: 'test@test.com',

        // 발신자 연락처
        senderTEL: '070-4304-2991',

        // 발신자 휴대폰번호
        senderHP: '000-111-222',

        /*************************************************************************
         *                             수신자 정보
         **************************************************************************/

        // 수신자 사업자번호
        receiverCorpNum: '8888888888',

        // 수신자 상호
        receiverCorpName: '수신자상호',

        // 수신자 대표자 성명
        receiverCEOName: '수신자 대표자 성명',

        // 수신자 주소
        receiverAddr: '수신자 주소',

        // 수신자 종사업장 식별번호, 필요시 기재
        recieverTaxRegID: '',

        // 수신자 종목
        receiverBizClass: '종목',

        // 수신자 업태
        receiverBizType: '업태',

        // 수신자 담당자명
        receiverContactName: '수신자 담당자 성명',

        // 수신자 메일주소
        receiverEmail: 'test@test.com',

        // 수신자 연락처
        receiverTEL: '070-1111-2222',

        // 수신자 휴대폰 번호
        receiverHP: '000111222',

        /*************************************************************************
         *                            전자명세서 기재정보
         **************************************************************************/

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

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

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

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

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

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

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


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

        detailList: [
            {
                serialNum: 1,                // 품목 일련번호 1부터 순차기재
                itemName: '품명',
                purchaseDT: '20190829',      // 구매일자
                qty: '1',                    // 수량
                unitCost: '10000',           // 단가
                spec: '규격',                 // 규격
                supplyCost: '10000',          // 공급가액
                tax: '1000',                  // 세액
                remark: '비고'
            },
            {
                serialNum: 2,                // 품목 일련번호 1부터 순차기재
                itemName: '품명2',
                purchaseDT: '20190829',      // 구매일자
                qty: '1',                    // 수량
                unitCost: '10000',           // 단가
                spec: '규격',                 // 규격
                supplyCost: '10000',          // 공급가액
                tax: '1000',                  // 세액
                remark: '비고'
            }
        ],


        /*************************************************************************
         *                               전자명세서 추가속성
         * - 추가속성에 관한 자세한 사항은 "[전자명세서 API 연동매뉴얼] >
         *   5.2. 기본양식 추가속성 테이블"을 참조하시기 바랍니다.
         **************************************************************************/

        propertyBag: {
            Balance: '2000',     // 전잔액
            Deposit: '500',      // 입금액
            CBalance: '2500'     // 현잔액
        }
    };

    statementService.registIssue(testCorpNum, statement,
        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 Statement</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>

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

팝빌 NodeJS SDK 전자명세서 Example

기술지원센터

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

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

연동문의