웹마스터 팁

홈페이지 접속자 국가 국기 표시 적용 방법입니다. 


1. IP to Country 자료 다운로드 및 수정

아래 링크에서 ip-country.csv.zip 파일을 다운로드 합니다.
http://ip-to-country.webhosting.info/node/view/6
압축 해제 후 엑셀로 파일을 열어보면 맨 첫줄이 다음과 같습니다.
[ 16777216, 17367039, AU, AUS, AUSTRALIA ]
앞의 두 칼럼은 IP Address 범위의 시작과 끝 값을 나타냅니다.
(범위 값 계산법 : IP가 111.222.333.444 인 경우 111 x (256x256x256) + 222 x (256x256) + 333 x 256 + 444)
세번째, 네번째 칼럼은 ISO 3166에 의거한 두글자, 세글자 국가 코드이고
마지막 칼럼은 ISO 3166에 의거한 국가 이름입니다.
이 중 네번째 칼럼인 세글자 국가 코드열을 삭제하여 아래와 같이 만들어 주고 저장해주세요.
[ 16777216, 17367039, AU, AUSTRALIA ]
어차피 세글자 국가코드는 사용할 일이 없으니 삭제하는거지만 그대로 하셔도 상관은 없습니다. 
DB Import 하실때 그 부분 적용해주시면 되겠습니다.

http://dev.maxmind.com/geoip/legacy/geolite/ 
위 링크에서 GeoLite Country CSV 형식을 다운로드 받아 첫번째 두번째 칼럼을 삭제해도 됩니다.
어느 데이터가 더 정확한지는 모르겠습니다. 
두가지 데이터 모두 4컬럼으로 수정한 파일 첨부했고, 추후 업데이트시 위 내용 참고하시면 되겠습니다.


2. 국기 이미지 다운로드

아래 링크에서 국가 이미지 파일을 다운로드 합니다.
http://ip-to-country.webhosting.info/node/view/91
FTP로 계정에 접속하여 루트(or XE폴더)에 iptocountry/img 폴더를 만든 뒤 다운로드 받은 이미지를 업로드해주세요.
적당한 크기(20x13) 로 수정한 파일을 첨부했습니다.


3. 1번에서 수정한 csv 파일 DB에 import 

PhpMyadmin 에 접속합니다.
iptocountry 라는 이름의 필드 4개짜리 테이블을 만듭니다.
1.PNG
Import 메뉴에서 1번에서 수정한 csv 파일을 선택해주시고
Format of imported file 은 CSV using LOAD DATA 선택, 파일로 테이블 대치하기, 
Ignore duplicate rows 체크, 필드 구분자는 [ , ] 로 수정 후 실행 버튼 클릭
2.PNG
Import has been succeessfully finished 메세지와 레코드수, 내용 누락 없이 import 되었는지 확인합니다.



4. 적용

아래 소스를 알맞게 수정해서 게시판 스킨이나 레이아웃 등의 원하는 위치에 넣어줍니다.
소스가 수정할때마다 사라져서 부득이하게 이미지로 올립니다.
첨부파일의 ipcountry.php 파일 내용과 같습니다. 복사해서 사용하세요.
3.PNG
글 작성자 혹은 댓글 작성자의 국가 국기 표시를 위해서는
글 작성자의 경우 {@ $dip = $oDocument->getIpaddress();}
댓글 작성자의 경우 {@ $dip = $comment->getIpaddress();}
구문을 위 소스 1번 라인 위 가장 상단에 덧붙여 주시고
5번 라인 마지막 부분 $ip 값을 $__Context->dip 로 변경해주시면 됩니다.


작년 초 정도에 모듈(+애드온)을 제작하다가 
프로그램 전공이 아니라 많은 난관에 부딪혀 일단 모듈화 작업은 포기입니다.
최대한 간단하게 정리해서 수동 적용 방법이라도 올려봅니다.
다른 분이 모듈화 혹은 더 나은 방법이나 방향으로 수정배포 하셔도 좋겠습니다.
위 내용에 문제점 있으면 댓글이나 쪽지 부탁드리구요.
궁금하신 점에 대한 답변은 아는 선에서 최대한 해드리겠습니다.
제목 글쓴이 날짜
XE 뿐만아닌 텍스타일까지 하위 주소 없이! 도메인으로 바로연결! [14] Garon 2009.07.29
저작권 없는 음악 사이트 [1] 오키도키 2009.08.03
사랑비 BGM 설치 부터 내 사이트에 적용까지 한방에!!!!! [2] 오키도키 2009.08.03
텔넷/ SSH 안 되는 계정에서 TAR로 데이터 백업/XE 설치하기 [5] Dream Of Veritas 2009.08.04
회원정보 손쉽게 엑셀 파일로 저장하기 [34] thejeon 2009.08.05
에디터가 까맣게 나오는 현상 [1] file kau 2009.08.06
1.1.5에서 1.2.4으로 업그레이드 할 때.. [3] 활주로 2009.08.06
XE 왕초보를 위한 글 [13] 휘즈 2009.08.06
알 수 없는 아이프레임이 심어졌을 때 (치명적인 바이러스) [6] jjabez 2009.08.08
Cooliris Embed a Wall 위젯 v2.0에 동영상 반영시키기 [3] file 철쌤 2009.08.08
홈페이지 헤더부분에 display.handler.class.php 오류발생시 급해결방법 [3] file 극마 2009.08.09
XE svn external link로 update하기 [7] 하늘03 2009.08.09
mixup 애드온 Textyle에서 찾을 수 없는 증상 해결 팁 [1] 라르게덴 2009.08.10
모든 사이트 운영하는분들 읽어보셨으면 좋겠네요 [6] file NEARSTORY 2009.08.12
파일첨부 에러가 날때 이렇게 하시면 됩니다. [5] file 밀림의 왕자 2009.08.12
하드 압축 하실때 tar cvfpz 쓰시는분들..... [3] 우리아기 2009.08.13
사이트 먹통 되었을 때 대처법 [4] LunarDream 2009.08.14
본문에 삽입된 그림의 확대기능이 작동하지 않는경우(XE Official Ver2 layout) [2] file 분홍곰 2009.08.14
게시글 조회수 바꾸기 [4] file 지B 2009.08.15
RSS를 활용한 HelloMaster 홈페이지 새글 알리미 설정하기 [3] file 퍼니온 2009.08.16