Study/Spring

[Spring] 우체국 우편번호 API 적용

성으니:) 2023. 6. 14. 11:20

 

 

 

우체국 우편번호 API 이용방법

 

 

 

 

 

 

 

 

 

기능 구현

1.  우체국 계약고객전용시스템 사이트에서 인증키 발급

 

 

 

2.  system.properties 파일에 인증키 저장 (혹은 application.properties)

### Postcode API App Key ###
postcode.app_key = 발급받은 인증키

 

 

3.  Jsoup Java HTML Parser를 pom.xml에 추가

<dependency>
    <groupId>org.jsoup</groupId>
    <artifactId>jsoup</artifactId>
    <version>1.15.3</version>
</dependency>

 

Jsoup

  • 간단히 외부 url에 접근하여 문서를 가져올 수 있게 지원
  • Html parse 라이브러리지만 xml도 파싱이 가능

 

 

 

4.  Controller에 코드 작성

    @Autowired
    protected Properties systemProp; // properties에 저장한 인증키 사용하기 위함


    @RequestMapping("/zipCodeList.do")
    public ModelAndView zipCodeList(UiDTO dto, HttpServletRequest request, HttpServletResponse response) throws Exception {
        Map<String, Object> data = new HashMap<String, Object>();

        String ZIPCODE_API_KEY = systemProp.getProperty("postcode.app_key");
        String ZIPCODE_API_URL = "http://biz.epost.go.kr/KpostPortal/openapi2";

        String address = dto.getString("strAddress"); // 프론트에서 입력받은 주소
        String page = dto.getString("strPage"); // 프론트에서 입력받은 이동할 페이지

        StringBuilder queryUrl = new StringBuilder();
        queryUrl.append(ZIPCODE_API_URL);
        queryUrl.append("?regkey=");
        queryUrl.append(ZIPCODE_API_KEY);
        queryUrl.append("&target=postNew");
        queryUrl.append("&query=");
        queryUrl.append(address.replaceAll(" ", ""));
        queryUrl.append("&countPerPage=50"); // 최대 출력 건수인 50으로 설정
        queryUrl.append("&currentPage=");
        queryUrl.append(page);

	// Jsoup을 통해 요청URL에 대한 결과 XML을 파싱
        Document document = Jsoup.connect(queryUrl.toString()).get();
        String errorCode = document.select("error_code").text();

        if(errorCode == null || errorCode.equals("")) {
            Elements elements = document.select("item");
            List<Map<String, Object>> list = new ArrayList<>();
            for(Element element : elements){
                Map<String, Object> param = new HashMap<String, Object>();
                param.put("ZIPCODE", element.select("postcd").text());
                param.put("ADDR", element.select("address").text());
                param.put("ADDR2", element.select("addrjibun").text());
                list.add(param);
            }

            // list 결과 put
            data.put("listMain", list);
            data.put("strTotalCount", document.select("totalCount").text());
            data.put("strTotalPage", document.select("totalPage").text());
            data.put("strCurrentPage", document.select("currentPage").text());
            data.put("strError", "");
        } else{
            String errorMessage = document.select("message").text();
            //data.put("errorCode", errorCode);
            data.put("strError", errorMessage);
        }

        return makeModel(data);
    }

 

 

 

 

 

 

참고 사이트

https://pjsprogram.tistory.com/6