튜토리얼
Visual Basic 개발환경에서 팝빌 SDK를 추가하여 전자명세서 즉시 발행 (RegistIssue) 함수를 구현하는 예시입니다.
1. POPBiLL SDK 추가
① 팝빌 연동자료실에서 Visual Basic SDK 예제코드 다운로드 후 압축을 해제합니다.
② 압축해제한 SDK 예제 프로젝트의 Linkhub/ Popbill*/ 폴더에 포함된 클래스모듈을 기존 프로젝트의 클래스모듈로 추가합니다.
2. POPBiLL SDK 설정
Window 폼 코드에 API Key 와 클래스를 선언하고 Form_Load() 서브모듈에 전자명세서 클래스 초기화 코드를 추가합니다.
① Form API Key, 클래스 객체 선언
Option Explicit
' 링크아이디
Private Const LinkID = "TESTER"
' 비밀키
Private Const SecretKey = "SwWxqU+0TErBXy/9TVjIPEnI0VTUMMSQZtJf3Ed8q3I="
' 전자명세서 서비스 객체 선언
Private StatementService As New PBDocService
② Form_Load() 서브모듈
Private Sub Form_Load()
' 전자명세서 서비스 객체 초기화
StatementService.Initialize LinkID, SecretKey
' 연동환경 설정, True-테스트, False-운영(Production), (기본값:False)
StatementService.IsTest = True
' 인증토큰 IP 검증 설정, True-사용, False-미사용, (기본값:True)
StatementService.IPRestrictOnOff = True
' 로컬시스템 시간 사용여부, True-사용, False-미사용, (기본값:False)
StatementService.UseLocalTimeYN = False
End Sub
3. RegistIssue 기능 구현
Form에 버튼을 생성하고 버튼의 Click Event 코드에 전자명세서 즉시 발행 (RegistIssue) 함수를 작성합니다.
Private Sub btnRegistIssue_Click()
Dim Statement As New PBStatement
Dim newDetail As PBDocDetail
Dim Response As PBResponse
Dim corpNum As String
Dim i
'팝빌회원 사업자번호
corpNum = "1234567890"
Statement.memo = "즉시 발행 메모"
'[필수] 기재상 작성일자, 날자형식(yyyyMMdd)
Statement.writeDate = "20220101"
'[필수] [영수, 청구, 없음] 중 기재
Statement.purposeType = "영수"
'[필수] 과세형태, {과세, 영세, 면세} 중 기재
Statement.taxType = "과세"
'맞춤양식코드, 공백처리시 기본양식으로 작성
Statement.formCode = ""
'[필수] 전자명세서 종류코드
Statement.itemCode = 121
'[필수] 문서번호, 숫자, 영문, '-', '_' 조합 (최대24자리)으로 사업자별로 중복되지 않도록 구성
Statement.mgtKey = "20220101-01"
'=========================================================================
' 발신자 정보
'=========================================================================
'발신자 사업자번호, '-' 제외 10자리
Statement.senderCorpNum = corpNum
'발신자 종사업장 식별번호, 필요시 기재, 형식은 숫자 4자리
Statement.senderTaxRegID = ""
'발신자 상호
Statement.senderCorpName = "발신자 상호"
'발신자 상호명
Statement.senderCEOName = "발신자 대표자 성명"
'발신자 주소
Statement.senderAddr = "발신자 주소"
'발신자 종목
Statement.senderBizClass = "발신자 종목"
'발신자 업태
Statement.senderBizType = "발신자 업태,업태2"
'발신자 담당자성명
Statement.senderContactName = "발신자 담당자명"
'발신자 이메일
Statement.senderEmail = "test@test.com"
'발신자 연락처
Statement.senderTEL = "070-7070-0707"
'발신자 휴대전화 번호
Statement.senderHP = "010-000-2222"
'=========================================================================
' 수신자 정보
'=========================================================================
'수신자 사업자번호, '-' 제외 10자리
Statement.receiverCorpNum = "8888888888"
'수신자 상호
Statement.receiverCorpName = "수신자 상호"
'수신자 대표자 성명
Statement.receiverCEOName = "수신자 대표자 성명"
'수신자 주소
Statement.receiverAddr = "수신자 주소"
'수신자 종목
Statement.receiverBizClass = "수신자 종목 "
'수신자 업태
Statement.receiverBizType = "수신자 업태"
'수신자 담당자명
Statement.receiverContactName = "수신자 담당자명"
'수신자 메일주소
'팝빌 개발환경에서 테스트하는 경우에도 안내 메일이 전송되므로,
'실제 거래처의 메일주소가 기재되지 않도록 주의
Statement.receiverEmail = "test@receiver.com"
'=========================================================================
' 전자명세서 기재사항
'=========================================================================
'[필수] 공급가액 합계
Statement.supplyCostTotal = "100000"
'[필수] 세액 합계
Statement.taxTotal = "10000"
'[필수] 합계금액, 공급가액 합계 + 세액 합계
Statement.totalAmount = "110000"
'기재 상 일련번호 항목
Statement.serialNum = "123"
'기재 상 비고 항목
Statement.remark1 = "비고1"
Statement.remark2 = "비고2"
Statement.remark3 = "비고3"
'사업자등록증 이미지 첨부여부
Statement.businessLicenseYN = False
'통장사본 이미지 첨부여부
Statement.bankBookYN = False
'발행시 알림문자 발송여부
Statement.smssendYN = True
'상세항목 추가. (배열 길이 제한 없음)
'일련번호(serialNum)은 1부터 순차적으로 기재하시기 바랍니다
Set Statement.detailList = New Collection
For i = 1 To 5
Set newDetail = New PBDocDetail
newDetail.serialNum = i '일련번호 1부터 순차 기재
newDetail.purchaseDT = "20220101" '거래일자(yyyyMMdd)
newDetail.itemName = "품명" + CStr(i) '품목명
newDetail.spec = "규격" '규격
newDetail.unit = "단위" '단위
newDetail.qty = "1" '수량 '소수점 2자리까지
newDetail.unitCost = "100000" '소수점 2자리까지
newDetail.supplyCost = "100000" '공급가액
newDetail.tax = "10000" '세액
newDetail.remark = "비고" '비고
newDetail.spare1 = "spare1" '여분1
newDetail.spare2 = "spare2" '여분2
newDetail.spare3 = "spare3" '여분3
newDetail.spare4 = "spare4" '여분4
newDetail.spare5 = "spare5" '여분5
Statement.detailList.Add newDetail
Next
'=========================================================================
'전자명세서 추가속성
' - 추가속성에 관한 자세한 사항은 아래의 URL 참조.
' - https://developers.popbill.com/guide/statement/java/introduction/statement-form#propertybag-table
'=========================================================================
Set Statement.propertyBag = CreateObject("Scripting.Dictionary")
Statement.propertyBag.Add "CBalance", "100000" '전잔액
Statement.propertyBag.Add "Deposit", "10000" '입금액
Statement.propertyBag.Add "Balance", "100000" '현잔액
Set Response = statementService.RegistIssue(corpNum, Statement)
If Response Is Nothing Then
MsgBox ("응답코드 : " + CStr(statementService.LastErrCode) + vbCrLf + "응답메시지 : " + statementService.LastErrMessage)
Exit Sub
End If
MsgBox ("응답코드 : " + CStr(Response.code) + vbCrLf + "응답메시지 : " + Response.message + vbCrLf + "팝빌 승인번호 : " + Response.invoiceNum)
End Sub
4. 결과 확인
함수 호출 반환 결과는 아래와 같습니다.
- 성공 : Response code 로 숫자 1 반환
- 실패 : PopbillException 으로 음의 정수 8자리 숫자값 오류코드와 오류메시지 반환 [오류코드]