홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
DAUM 우편번호 서비스 활용하기
6년 전
이전부터 사용하던 그누보드4의 기능중에 자주 사용하지 않아서 모르고 있었던 변화가 있었더군요. 회원가입이나  회원 정보 수정에서 주소 입력에 사용하던 우편번호 검색 기능입니다. 기존 코드에서 AJAX 방식으로 sir.co.kr 사이트에서 정보를 검색 및 출력해 주는 방식이었는데 sir.co.kr에서 더이상 지원하지 않는다는 공지가 있더군요. 늦었지만 해결 방법을 찾아보니 다른 분이 주소만 바꾸면 동일한 방식으로 사용할 수 있도록 서비스를 제공하기도 하지만 근원적인 해결 방법이 아니고 또 새로운 우편번호 체계를 적용하는 문제와 지속적인 데이터베이스 업데이트를 생각한 다면 포털에서 제공하는 서비스를 적용하는 것이 적절하다고 생각 되었습니다. 무엇보다 아래와 같은 장점이 있었습니다.

•별도의 등록 과정이 필요없습니다.
OPENAPI만 하더라도 개발자 등록과 키발급등의 과정이 필요했습니다.

•트래픽 제한이 없습니다.
OPENAPI의 경우에는 일 트래픽 제한이 있습니다.

•무엇보다 무료이고, 친절한 예제와 빠른 속도는 마음에 쏙 들었습니다.

•우편번호 데이터베이스의 최신 업데이트에 대한 부담이 없어졌습니다.

•최근 해외 배송으로 영문 주소 활용에 대한 필요가 늘고 있는데 그에 대한 자연스러운 대처가 가능합니다.

•맵과의 연동, 자동 완성등 다양한 부가 기능을 제공합니다.

이상의 장점을 활용하는 예제로 그누보드4의 우편번호 검색 기능을 DAUM 우편번호 서비스로 교체하는 과정을 다루어 보겠습니다.

우선 DAUM 우편번호 서비스의 사이트 주소는 http://postcode.map.daum.net/guide입니다. 상단의 예제와 함수등을 참조하면 더욱 다듬어진 응용을 개발하실 수 있습니다.

<script src="http://dmaps.daum.net/map_js_init/postcode.v2.js"></script><script src="http://s1.daumcdn.net/svc/attach/U03/cssjs/postcode/1448959281377/151201.js" type="text/javascript" charset="UTF-8"></script>
<script>
    function execDaumPostcode() {
        new daum.Postcode({
            oncomplete: function(data) {
                // 팝업에서 검색결과 항목을 클릭했을때 실행할 코드를 작성하는 부분.

                // 도로명 주소의 노출 규칙에 따라 주소를 조합한다.
                // 내려오는 변수가 값이 없는 경우엔 공백('')값을 가지므로, 이를 참고하여 분기 한다.
                var fullRoadAddr = data.roadAddress; // 도로명 주소 변수
                var extraRoadAddr = ''; // 도로명 조합형 주소 변수

                // 법정동명이 있을 경우 추가한다. (법정리는 제외)
                // 법정동의 경우 마지막 문자가 "동/로/가"로 끝난다.
                if(data.bname !== '' && /[동|로|가]$/g.test(data.bname)){
                    extraRoadAddr += data.bname;
                }
                // 건물명이 있고, 공동주택일 경우 추가한다.
                if(data.buildingName !== '' && data.apartment === 'Y'){
                   extraRoadAddr += (extraRoadAddr !== '' ? ', ' + data.buildingName : data.buildingName);
                }
                // 도로명, 지번 조합형 주소가 있을 경우, 괄호까지 추가한 최종 문자열을 만든다.
                if(extraRoadAddr !== ''){
                    extraRoadAddr = ' (' + extraRoadAddr + ')';
                }

                // 우편번호와 주소 정보를 해당 필드에 넣는다.
                //document.getElementById('sample4_postcode').value = data.zonecode; //5자리 새우편번호 사용
                document.getElementById('mb_zip1').value = data.postcode1;
                document.getElementById('mb_zip2').value = data.postcode2;
                document.getElementById('mb_addr1').value = fullRoadAddr;
                document.getElementById('mb_addr3').value = extraRoadAddr;
                document.getElementById('mb_addr_jibeon').value = data.jibunAddress;
                document.getElementById('mb_addr_jibeonview').innerHTML = data.jibunAddress;
            }
        }).open('',100,100,'zipsearch');
    }
</script>
위의 HTML 은 그누보드4의 회원 가입 코드인 skin/member/basic 폴더의 register_form.skin.php의 주소 연관 부분 입니다. 기존과 달라진 점이라면 각 텍스트 항목에 name= 뿐만아니라 id=로 개별 항목을 document.getElementById()로 자바스크립트에서 접근할 수 있도록 추가해준것과 우편번호 검색 이미지를 클릭하면 DAUM의 자바스크립트 함수가 호출되도록 했다는 것입니다. 하단에서 정의한 execDaumPostcode()에 해당하며 이 함수를 통해서 팝업을 띄우고 사용자가 검색된 주소중 하나를 클릭하면 그 결과를 각 텍스트 항목에 입력합니다.  함수 끝부분에 있는 "open('',100,100,'zipsearch')" 부분이 팝업 창을 띄우는 부분으로 4번째 인수가 창의 이름을 지정하는 부분으로 이 이름을 통해서 창을 여러개 중복해서 띄우지 않도록 예방할 수 있습니다. 첫번째 인수는 기본 검색어, 두번째와 세번째 위칭의 창의 위치를 지정합니다. 함수내에 주석처리되어 있는 "data.zonecode" 변수를 통해서 5자리 새우편번호를 사용할 수 있습니다.
추천추천 : 291 추천 목록
번호 제목
3,033
 PHP 정규식 정리
3,032
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
3,031
 php 크롤링 또는 파싱 함수, 정규식 모음
3,030
 제이쿼리 기본 명령어
3,029
 웹페이지 가로 모드세로 모드 인식하기
3,028
 모바일 웹 화면 강제 회전(가로모드 고정)
3,027
 [HTML5]에서 frameset 대체 방법과 iframe 속성
3,026
 HTML <Audio> 사용법
3,025
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
3,024
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,023
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,022
 CSS Layout 수평 & 수직 정렬
3,021
 여러 도메인들 간 쿠키 공유하기
3,020
 태그 사이에 있는 텍스트를 추출
3,019
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,018
 쿠키 생성,가져오기,삭제
3,017
 사용자 함수 모음
3,016
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,015
 [HTML5] <video> - DOM으로 제어하기
3,014
 HTML5 video 태그에서 영상 좌우반전
3,013
 PHP - 특정 태그 및 문자열 추출, 제거
3,012
 [PHP] define과 defined의 차이
3,011
 우클릭 완벽차단 스크립트
3,010
 iframe 높이 100% 맞추기
3,009
 curl 함수를 이용한 HTTP REFERER 변경
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.