[Node.js] 팝빌 현금영수증 SDK 튜토리얼
Express 개발환경에서 NPM을 이용해 팝빌 Node.js SDK를 추가한 후 현금영수증 즉시발행(RegistIssue) SDK 함수를 구현하는 예시입니다.
1. NPM 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.53.0"
}
}
② 프로젝트 routes 폴더 하위의 index.js 파일에 연동신청시 발급받은 인증정보를 변수로 선언하고 아래의 코드를 참조하여 현금영수증 서비스 객체를 생성 합니다.
연동신청시 발급받은 인증정보로 링크아이디(LinkID)와 비밀키(SecretKey) property 값을 변경하시기 바랍니다.
// 생략..
var popbill = require('popbill');
popbill.config( {
// 링크허브에서 발급받은 링크아이디, 비밀키
LinkID :'TESTER',
SecretKey : 'SwWxqU+0TErBXy/9TVjIPEnI0VTUMMSQZtJf3Ed8q3T=',
// 연동환경 설정값, (true-개발용, false-상업용)
IsTest : true,
// 인증토큰 IP제한기능 사용여부, 권장(true)
IPRestrictOnOff: true,
// 팝빌 API 서비스 고정 IP 사용여부
UseStaticIP: false,
// 로컬시스템 시간 사용여부 true-사용(기본값-권장), false-미사용
UseLocalTimeYN: true,
defaultErrorHandler: function (Error) {
console.log('Error Occur : [' + Error.code + '] ' + Error.message);
}
});
var cashbillService = popbill.CashbillService();
// 생략..
③ 팝빌 Node.js Examlpe을 실행한다면, app.js 파일의 Router handler, app.use 부분에 사용하지 않는 서비스를 주석 처리합니다.
// Router handler
//var taxinvoice = require('./routes/taxinvoice');
//var statement = require('./routes/statement');
var cashbill = require('./routes/cashbill');
//var message = require('./routes/message');
//var kakao = require('./routes/kakao');
//var fax = require('./routes/fax');
//var htTaxinvoice = require('./routes/httaxinvoice');
//var htCashbill = require('./routes/htcashbill');
//var closedown = require('./routes/closedown');
//var easyfinbank = require('./routes/easyfinbank');
//var accountCheck = require('./routes/accountCheck');
// 생략 ..
//app.use(route URI Schema, route handler)
//app.use('/TaxinvoiceService', taxinvoice);
//app.use('/StatementService', statement);
app.use('/CashbillService', cashbill);
//app.use('/MessageService', message);
//app.use('/KakaoService', kakao);
//app.use('/FaxService', fax);
//app.use('/HTTaxinvoiceService', htTaxinvoice);
//app.use('/HTCashbillService', htCashbill);
//app.use('/ClosedownService', closedown);
//app.use('/EasyFinBankService', easyfinbank);
//app.use('/AccountCheckService', accountCheck);
2. 현금영수증 즉시발행(RegistIssue) 기능 구현
① index.js 파일에 현금영수증 즉시발행(RegistIssue) 함수 호출 코드를 추가합니다.
router.get('/registIssue', function (req, res, next) {
// 팝빌회원 사업자번호, '-' 제외 10자리
var testCorpNum = '1234567890';
// 문서번호, 1~24자리 숫자, 영문, '-', '_'를 조합하여 사업자별로 중복되지 않도록 작성
var MgtKey = '20220101-031';
//현금영수증 상태메모
var stateMemo = "발행메모";
// 현금영수증 항목
var cashbill = {
// [필수] 문서번호
mgtKey: MgtKey,
// [필수] 문서형태, (승인거래, 취소거래) 중 기재
tradeType: '승인거래',
// [취소 현금영수증 발행시 필수] 원본 현금영수증 국세청 승인번호
// 국세청 승인번호는 GetInfo API의 ConfirmNum 항목으로 확인할 수 있습니다.
orgConfirmNum: '',
// [취소 현금영수증 발행시 필수] 원본 현금영수증 거래일자
// 원본 현금영수증 거래일자는 GetInfo API의 TradeDate 항목으로 확인할 수 있습니다.
orgTradeDate: '',
// [필수] 과세형태 (과세, 비과세) 중 기재
taxationType: '과세',
// [필수] 거래구분 (소득공제용, 지출증빙용) 중 기재
tradeUsage: '소득공제용',
// 거래유형 (일반, 도서공연, 대중교통) 중 기재
tradeOpt: '일반',
// [필수] 거래처 식별번호, 거래유형에 따라 작성
// 소득공제용 - 주민등록/휴대폰/카드번호 기재가능
// 지출증빙용 - 사업자번호/주민등록/휴대폰/카드번호 기재가능
identityNum: '0101112222',
// [필수] 가맹점 사업자번호
franchiseCorpNum: testCorpNum,
// 가맹점 종사업장 식별번호
franchiseTaxRegID: '',
// 가맹점 상호
franchiseCorpName: '가맹점 상호',
// 가맹점 대표자성명
franchiseCEOName: '가맹점 대표자 성명',
// 가맹점 주소
franchiseAddr: '가맹점 주소',
// 가맹점 연락처
franchiseTEL: '01012341234',
// [필수] 공급가액
supplyCost: '10000',
// [필수] 세액
tax: '1000',
// [필수] 봉사료
serviceFee: '0',
// [필수] 거래금액 (공급가액 + 세액 + 봉사료)
totalAmount: '11000',
// 고객명
customerName: '고객명',
// 상품명
itemName: '상품명',
// 주문번호
orderNumber: '주문번호',
// 고객 메일주소
// 팝빌 개발환경에서 테스트하는 경우에도 안내 메일이 전송되므로,
// 실제 거래처의 메일주소가 기재되지 않도록 주의
email: 'test@test.com',
// 고객 핸드폰번호
hp: '010111222',
// 고객 팩스번호
fax: '000111222',
// 발행시 알림문자 전송여부
// 문자전송시 포인트가 차감되며 전송실패시 환불처리됨.
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>
③ 웹브라우저에서 페이지를 호출하여 함수호출 결과를 확인합니다.
