안녕하세요. 고객의 가치를 연결하는 비즈니스 파트너 링크허브 입니다.
본 포스팅에서는 Java - Spring 개발환경에서 고객사들이 팝빌 홈택스 전자세금계산서 조회 API SDK를 쉽고 빠르게 이용할 수 있도록, 예시를 이용하여 연동 설정 방법을 안내드리겠습니다. 먼저, Maven을 이용해 팝빌 SDK를 추가한 후 수집요청(RequestJob), 수집상태확인(GetJobState) 함수를 구현하는 순서로 진행하겠습니다.
팝빌 SDK는 JDK V1.6 개발환경에 최적화 되어 있으며, API 호출과 응답의 메시지 인코딩은 "UTF-8 Character-Set"을 지원합니다.
"팝빌은 링크허브에서 자체 개발하고 직접 운영하는 홈택스 전자세금계산서 조회 서비스 Brand Name 입니다."
아래 설명하는 예시는 [ JDK v1.6 | Tomcat v7 | STS v3.6.4 ] 기준으로 작성되어 있어, 이용 중이신 개발환경과 차이가 있을 수 있는 점 감안해 주시기 바랍니다.
1. Popbill SDK 추가
① Maven 업데이트를 위해 "pom.xml" 파일에 팝빌 SDK Dependency를 추가하고 메이븐 업데이트를 진행합니다.
<dependency>
<groupId>kr.co.linkhub</groupId>
<artifactId>popbill-sdk</artifactId>
<version>1.20.0</version>
</dependency>
② 홈택스 전자세금계산서 조회 서비스 클래스를 빈으로 등록하기 위해 아래코드를 참조하여 "servlet-context.xml" 파일을 수정합니다.
<?xml version="1.0" encoding="UTF-8"?>
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd">
<!-- DispatcherServlet Context: defines this servlet's request-processing infrastructure --><!-- Enables the Spring MVC @Controller programming model --><annotation-driven />
<!-- Handles HTTP GET requests for /resources/** by efficiently serving up static resources in the ${webappRoot}/resources directory --><resources mapping="/resources/**" location="/resources/" />
<!-- Resolves views selected for rendering by @Controllers to .jsp resources in the /WEB-INF/views directory --><beans:bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><beans:property name="prefix" value="/WEB-INF/views/" /><beans:property name="suffix" value=".jsp" /></beans:bean><context:component-scan base-package="kr.test.popbill" />
<util:properties id="EXAMPLE_CONFIG">
<!-- 링크아이디 --> <beans:prop key="LinkID">TESTER</beans:prop>
<!-- 비밀키 --> <beans:prop key="SecretKey">SwWxqU+0TErBXy/9TVjIPEnI0VTUMMSQZtJf3Ed8q3I=</beans:prop>
<!-- 연동환경 설정값 true(개발용), false(상업용) --> <beans:prop key="IsTest">true</beans:prop>
<!-- 인증토큰 아이피 제한 기능 사용여부 권장(true) --> <beans:prop key="IsIPRestrictOnOff">true</beans:prop> </util:properties>
<beans:beans>
<!-- 홈택스 전자세금계산서 Service Implementation Bean registration. -->
<beans:bean id="htTaxinvoiceService" class="com.popbill.api.hometax.HTTaxinvoiceServiceImp">
<beans:property name="linkID" value="#{EXAMPLE_CONFIG.LinkID}"/>
<beans:property name="secretKey" value="#{EXAMPLE_CONFIG.SecretKey}"/>
<beans:property name="test" value="#{EXAMPLE_CONFIG.IsTest}"/>
<beans:property name="IPRestrictOnOff" value="#{EXAMPLE_CONFIG.IsIPRestrictOnOff}"/>
</beans:bean>
</beans:beans>
</beans:beans>
▶ 링크허브에서 발급받은 고객사 인증정보로 링크아이디(LinkID)와 비밀키(SecretKey) 값을 변경하시기 바랍니다.
3. API 구현
API를 구현하기 전, 홈택스 전자세금계산서 조회를 위한 함수 프로세스 순서도를 먼저 살펴보시기 바랍니다.
① 수집작업 요청 (RequestJob), 작업상태확인(GetJobState) 함수를 테스트하기 위해 TaskController.java 를 생성하고 GET Request URL을 처리하는 코드를 추가합니다.
- 예제코드를 참조하여 @Controller 어노테이션 과 홈택스 전자세금계산서 서비스 빈 객체주입을 위한 @Autowired 어노테이션을 추가합니다.
- Search API 에 관한 예제는 제공되는 SpringMVC SDK 예제코드 /com.popbill.example/HTTaxinvoiceExample.java 에 선언된 Search() 함수를 참조하시기 바랍니다.
- RequestJob 호출시 반환되는 JobID를 GetJobState 함수 파라미터로 기재하여 호출합니다.
② API 호출결과 출력을 위해 "src/main/webapp/WEB-INF/views/response.jsp" 페이지를 추가합니다.
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><head><title>Response </title>
</head><body><c:if test="${JobID != null}"><p>작업아이디 (JobID) : ${JobID}</p>
</c:if>
<c:if test="${JobState != null}"><p>JobID (작업아이디) : ${JobState.jobID}</p>
<p>jobState (수집상태) : ${JobState.jobState}</p>
<p>queryType (수집유형) : ${JobState.queryType}</p>
<p>queryDateType (일자유형) : ${JobState.queryDateType}</p>
<p>queryStDate (시작일자) : ${JobState.queryStDate}</p>
<p>queryEnDate (종료일자) : ${JobState.queryEnDate}</p>
<p>errorCode (오류코드) : ${JobState.errorCode}</p>
<p>jobStartDT (작업 시작일시) : ${JobState.jobStartDT}</p>
<p>jobEndDT (작업 종료일시) : ${JobState.jobEndDT}</p>
<p>collectCount (수집개수) : ${JobState.collectCount}</p>
<p>regDT (수집 요청일시) : ${JobState.regDT}</p>
</c:if>
<c:if test="${Response != null}"><p>Response.code : ${Response.code}</p>
<p>Response.message : ${Response.message}</p>
</c:if></body></html>
③ 함수 호출결과를 확인합니다.
예) 수집요청 (RequestJob) 함수호출 성공처리 - 작업아이디(JobID) 반환
예) 수집결과확인 (GetJobState) 함수호출 성공처리
예) 함수호출 실패처리 - 오류코드(-로 시작하는 8자리 숫자값), 오류메시지(사유에 대한 설명) 반환
[참고] 팝빌 연동 개발을 위한 테스트베드(개발용) 안내 - https://linkhub.tistory.com/91
팝빌에서 제공하는 다양한 API는 동일한 컨셉으로 개발되어 있어, 하나의 서비스를 이용한 경험이 있으면 다른 서비스들도 유사한 방법으로 빠르게 연동이 가능하니 많은 이용 부탁드립니다.
지금까지 JAVA - Spring 개발환경에서 홈택스 전자세금계산서 조회 API를 연동하는 방법에 대해 안내해 드렸습니다. 내용에 대한 추가적인 문의가 있으면 기술지원센터로 편하게 연락주시기 바랍니다.
고객사의 편의를 위하여 이메일, 전화 등 다양한 채널을 열어놓고 있으니 언제든지 연락 주시기 바랍니다.
기술지원센터 / T. 1600-9854 / E. code@linkhub.co.kr
'가치를 연결하다 > 튜토리얼' 카테고리의 다른 글
[Node.js] 팝빌 전자명세서 API 연동 가이드 (0) | 2019.02.21 |
---|---|
[Java - Spring] 팝빌 홈택스 현금영수증 조회 API 연동 가이드 (0) | 2019.02.21 |
[Java - Spring] 팝빌 카카오톡 API 연동 가이드 (0) | 2019.02.21 |
[Java - Spring] 팝빌 휴폐업조회 API 연동 가이드 (0) | 2019.02.21 |