관련작업을 하다가 검색을 통해 구현해봤습니다.
쓰일일이 잘 없겠지만, 국가별경우 제어하는 경우는 생길수 있어 응용하시면 되겠습니다.
알고리즘은 매우간단합니다. 전세계 ip 범위에 따른 국가명 파일인 csv 파일을 db에 저장한후 실제아이피와 비교하면 간단하겠습니다.
아래경로에서 csv파일을 받습니다.
http://ip-to-country.webhosting.info/node/view/6
그리고 아래 소스나갑니다.
<?
mysql_query("
CREATE TABLE `ip2c` (
`start` int(10) unsigned NOT NULL default '0',
`end` int(10) unsigned NOT NULL default '0',
`a2` char(2) NOT NULL default '',
`a3` char(3) NOT NULL default '',
`country` varchar(100) NOT NULL default '',
PRIMARY KEY (`start`,`end`)
);
");
$lines=file('./ip-to-country.csv');
foreach($lines as $line){
$line=trim($line);
if(!preg_match('/^"([0-9]+)","([0-9]+)","(.{2})","(.{3})","(.*)"$/',$line,$matches)){
echo "error";
}else{
mysql_query('insert into ip2c values("'.($matches[1]).'","'.($matches[2]).'","'.($matches[3]).'","'.($matches[4]).'","'.($matches[5]).'");') or die(mysql_error());
}
}
?>
위 소스는 위 사이트 댓글에 나와있는 소스인데, 한번 실행주고 나면 필요없습니다.
그런후, 아래함수를 통해 국가 이미지를 추출해낼수 있겠습니다.
function flag($ip){
$re_flag=mysql_fetch_array(mysql_query("select a2 from ip2c where start<='$ip' and end>='$ip'"));//2자,3자,전체에따라 a2,a3,country
if($re_flag[a2]) $flag=$re_flag[a2];
else $flag="kr";
return $flag;
}
//예제
$expip=explode(".",$ip);
$flag=flag(($expip[0]*256*256*256)+($expip[1]*256*256)+($expip[2]*256)+$expip[3]);
$flagimg="<img src=\"국가이미지경로/".strtolower($flag).".png\" align='absmiddle'>";
echo $flagimg;
참고로 위소스는 국가이미지가 소문자 2자로 나오는경우(a2)입니다. 국가이미지를 어디서 받았는지 기억이 없어서;;;
검색하시면 전체이름으로 나오는 국가이미지도 있으니, 그에맞게 하시면 되겠습니다.
참고로, 쿼리문에서 a2는 2자국가명,a3는 3자국가명, country는 전체국가명입니다.
** 부호반대로 준거 수정 ㅡ.ㅡ<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]</div>
쓰일일이 잘 없겠지만, 국가별경우 제어하는 경우는 생길수 있어 응용하시면 되겠습니다.
알고리즘은 매우간단합니다. 전세계 ip 범위에 따른 국가명 파일인 csv 파일을 db에 저장한후 실제아이피와 비교하면 간단하겠습니다.
아래경로에서 csv파일을 받습니다.
http://ip-to-country.webhosting.info/node/view/6
그리고 아래 소스나갑니다.
<?
mysql_query("
CREATE TABLE `ip2c` (
`start` int(10) unsigned NOT NULL default '0',
`end` int(10) unsigned NOT NULL default '0',
`a2` char(2) NOT NULL default '',
`a3` char(3) NOT NULL default '',
`country` varchar(100) NOT NULL default '',
PRIMARY KEY (`start`,`end`)
);
");
$lines=file('./ip-to-country.csv');
foreach($lines as $line){
$line=trim($line);
if(!preg_match('/^"([0-9]+)","([0-9]+)","(.{2})","(.{3})","(.*)"$/',$line,$matches)){
echo "error";
}else{
mysql_query('insert into ip2c values("'.($matches[1]).'","'.($matches[2]).'","'.($matches[3]).'","'.($matches[4]).'","'.($matches[5]).'");') or die(mysql_error());
}
}
?>
위 소스는 위 사이트 댓글에 나와있는 소스인데, 한번 실행주고 나면 필요없습니다.
그런후, 아래함수를 통해 국가 이미지를 추출해낼수 있겠습니다.
function flag($ip){
$re_flag=mysql_fetch_array(mysql_query("select a2 from ip2c where start<='$ip' and end>='$ip'"));//2자,3자,전체에따라 a2,a3,country
if($re_flag[a2]) $flag=$re_flag[a2];
else $flag="kr";
return $flag;
}
//예제
$expip=explode(".",$ip);
$flag=flag(($expip[0]*256*256*256)+($expip[1]*256*256)+($expip[2]*256)+$expip[3]);
$flagimg="<img src=\"국가이미지경로/".strtolower($flag).".png\" align='absmiddle'>";
echo $flagimg;
참고로 위소스는 국가이미지가 소문자 2자로 나오는경우(a2)입니다. 국가이미지를 어디서 받았는지 기억이 없어서;;;
검색하시면 전체이름으로 나오는 국가이미지도 있으니, 그에맞게 하시면 되겠습니다.
참고로, 쿼리문에서 a2는 2자국가명,a3는 3자국가명, country는 전체국가명입니다.
** 부호반대로 준거 수정 ㅡ.ㅡ<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]</div>
댓글 1개
15년 전
그래서 구글에서 자꾸 내 아이피를 중국이라 했었구나..
제 아이피는 중국으로 분류되어있네요.
제 아이피는 중국으로 분류되어있네요.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 7730 | 10년 전 | 1275 | ||
| 7729 | 10년 전 | 1085 | ||
| 7728 |
잘살아보자
|
10년 전 | 554 | |
| 7727 |
잘살아보자
|
10년 전 | 457 | |
| 7726 |
잘살아보자
|
10년 전 | 794 | |
| 7725 |
잘살아보자
|
10년 전 | 518 | |
| 7724 |
잘살아보자
|
10년 전 | 429 | |
| 7723 |
잘살아보자
|
10년 전 | 497 | |
| 7722 |
잘살아보자
|
10년 전 | 432 | |
| 7721 |
잘살아보자
|
10년 전 | 471 | |
| 7720 |
잘살아보자
|
10년 전 | 410 | |
| 7719 |
비긴어게인
|
10년 전 | 654 | |
| 7718 |
|
10년 전 | 2499 | |
| 7717 |
잘살아보자
|
10년 전 | 629 | |
| 7716 |
잘살아보자
|
10년 전 | 370 | |
| 7715 |
잘살아보자
|
10년 전 | 409 | |
| 7714 |
잘살아보자
|
10년 전 | 442 | |
| 7713 | 10년 전 | 1746 | ||
| 7712 | 10년 전 | 1679 | ||
| 7711 | 10년 전 | 1067 | ||
| 7710 | 10년 전 | 1348 | ||
| 7709 | 10년 전 | 1482 | ||
| 7708 | 10년 전 | 1434 | ||
| 7707 | 10년 전 | 820 | ||
| 7706 |
별지기천사
|
10년 전 | 548 | |
| 7705 | 10년 전 | 1045 | ||
| 7704 |
ICONdesignstudio
|
10년 전 | 589 | |
| 7703 | 10년 전 | 549 | ||
| 7702 |
|
10년 전 | 686 | |
| 7701 | 10년 전 | 1382 | ||
| 7700 | 10년 전 | 1079 | ||
| 7699 | 10년 전 | 562 | ||
| 7698 | 10년 전 | 1108 | ||
| 7697 | 10년 전 | 5118 | ||
| 7696 | 10년 전 | 607 | ||
| 7695 | 10년 전 | 1651 | ||
| 7694 | 10년 전 | 1019 | ||
| 7693 | 10년 전 | 1513 | ||
| 7692 | 10년 전 | 1251 | ||
| 7691 | 10년 전 | 783 | ||
| 7690 | 10년 전 | 1360 | ||
| 7689 | 10년 전 | 978 | ||
| 7688 | 10년 전 | 557 | ||
| 7687 |
파랑새1597
|
10년 전 | 555 | |
| 7686 | 10년 전 | 803 | ||
| 7685 | 10년 전 | 1320 | ||
| 7684 | 10년 전 | 772 | ||
| 7683 | 10년 전 | 1018 | ||
| 7682 | 10년 전 | 896 | ||
| 7681 | 10년 전 | 619 | ||
| 7680 | 10년 전 | 956 | ||
| 7679 | 10년 전 | 454 | ||
| 7678 | 10년 전 | 693 | ||
| 7677 | 10년 전 | 597 | ||
| 7676 |
|
10년 전 | 915 | |
| 7675 |
|
10년 전 | 1117 | |
| 7674 | 10년 전 | 1030 | ||
| 7673 | 10년 전 | 727 | ||
| 7672 | 10년 전 | 1055 | ||
| 7671 | 10년 전 | 849 | ||
| 7670 | 10년 전 | 604 | ||
| 7669 |
mashmellow
|
10년 전 | 1202 | |
| 7668 | 10년 전 | 679 | ||
| 7667 | 10년 전 | 960 | ||
| 7666 |
senseme
|
10년 전 | 626 | |
| 7665 | 10년 전 | 478 | ||
| 7664 | 10년 전 | 1870 | ||
| 7663 |
mixx애교
|
10년 전 | 954 | |
| 7662 | 10년 전 | 986 | ||
| 7661 |
hkhkah
|
10년 전 | 755 | |
| 7660 | 10년 전 | 1039 | ||
| 7659 |
커네드커네드
|
10년 전 | 909 | |
| 7658 |
바람돌이팡
|
10년 전 | 639 | |
| 7657 | 10년 전 | 1132 | ||
| 7656 | 10년 전 | 1544 | ||
| 7655 | 10년 전 | 954 | ||
| 7654 |
개발짜증나
|
10년 전 | 833 | |
| 7653 |
네이비칼라
|
10년 전 | 865 | |
| 7652 |
밥먹고합시다
|
10년 전 | 784 | |
| 7651 |
플라이SINJI
|
10년 전 | 1485 | |
| 7650 |
개발짜증나
|
10년 전 | 1378 | |
| 7649 | 10년 전 | 431 | ||
| 7648 |
이미영ㅇㅇ
|
10년 전 | 837 | |
| 7647 | 10년 전 | 409 | ||
| 7646 | 10년 전 | 775 | ||
| 7645 | 10년 전 | 2274 | ||
| 7644 | 10년 전 | 794 | ||
| 7643 |
|
10년 전 | 2837 | |
| 7642 | 10년 전 | 1490 | ||
| 7641 | 10년 전 | 1109 | ||
| 7640 |
개발짜증나
|
10년 전 | 452 | |
| 7639 |
|
10년 전 | 788 | |
| 7638 |
개발짜증나
|
10년 전 | 1093 | |
| 7637 | 10년 전 | 1513 | ||
| 7636 | 10년 전 | 2881 | ||
| 7635 | 10년 전 | 1660 | ||
| 7634 | 10년 전 | 1823 | ||
| 7633 | 10년 전 | 2293 | ||
| 7632 | 10년 전 | 3892 | ||
| 7631 |
|
10년 전 | 1504 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기