홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취

okTrot(구독하세요)
KongMusic(구독하세요)
음악가사 검색
온라이브스토어(앱다운로드)
온라이브(방송등록및청취)
Search Video Best 50
금영노래방
TJ노래방
유튜브 동영상 다운로드
POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
운.영.자.1대1.상담
FAQ\지원.프로그램
Q&A\고.객.지.원

자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
DAUM 우편번호 서비스 활용하기
1년 전
이전부터 사용하던 그누보드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자리 새우편번호를 사용할 수 있습니다.
추천추천 : 154 추천 목록
번호 제목
3,012
 텍스트 줄바꿈, 글자자르기 CSS
3,011
 jQuery Mobile에서 유용한 코드 10가지.
3,010
 [PHP] dirname()함수와 $_SERVER 관련 상수들
3,009
 [PHP] 파일 크기, 사이즈 불러오는 함수, filesize()
3,008
 [jQuery] jQuery Quick API
3,007
 [ transition ] 링크 hover 색상 변화 속도 조절
3,006
 PHP 5.3.0 에서 사라진 함수들 대체
3,005
 어떤 파일들이 include 나 require 되었는지 확인하는 함수(get_included_files)
3,004
 PHP 날짜 형식 및 계산하기(날짜 더하고 빼기)
3,003
 jQuery Mobile에서 유용한 코드 10가지.
3,002
 값이 배열 안에 존재하는지 확인하는 in_array함수
3,001
 사용자가 웹브라우저에서 뒤로가기를 했을때 감지하는 방법
3,000
 [jQuery]버튼 활성화, 비활성화
2,999
 jQuery show() / hide() / toggle() 사용법
2,998
 jquery 여러가지 이벤트
2,997
 border-radius 속성
2,996
 네이버 오픈API 음성합성 API 사용하는 PHP 샘플코드
2,995
 UTF8 한글 자르기..
2,994
 iconv 에러 발생시 계속 처리하기 옵션
2,993
 [PHP] 현재 페이지의 도메인 , URL 정보 알아내기.
2,992
 [PHP] 막강 기능 배열..
2,991
 [CSS] - Input clear `X ` 버튼 제거 ( IE, Chrome, Firefox )
2,990
 [Mobile] - 모바일웹 Href 태그속성들
2,989
 [JqueryMobile] - 현재화면의 가로세로 사이즈 구하기
2,988
 [JqueryMobile] - 화면의 가로, 세로 사이즈 구하는 방법
2,987
 jquery로 가로 넓이(width), 세로 높이(height) 자동 조절
2,986
 iframe 높이 jquery로 자동조절하기
2,985
 jQuery 오른쪽 영역의 높이를 왼쪽 영역의 높이와 동일하게 하기
2,984
 jquery에서 테이블 짝수, 홀수 번째 TR 배경색 변경하기
2,983
 jquery에서 테이블에 마우스 오버시 해당 행의 배경색상 변경하기
2,982
 jquery 스크립트내 특정값 확인하기 (디버깅)
2,981
 jquery cookie (jquery.cookie.js)
2,980
 jquery div 기본 넓이, 높이 계산 및 padding, border 포함 하기
2,979
 jquery 다른버전 추가 사용시 충돌 방지 (카페24 스마트디자인 기본내장 jquery 1.4.4 버전과 충돌시 해결방법)
2,978
 특정 페이지 종료시 확인 경고창 출력
목록
추천음악방송
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
콩뮤직
작은 음악다방
종합성인가요방
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
Dance&Remix
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요1번지(종합)
뮤직하우스
동요\연변\반주\기타
앗싸! 뽕짝
가요 포장마차
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
추천가요\POP\기타
최신가요\인기가요
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.