當咱們在頁面中填寫我的資料中的省市信息時,頁面會根據當前用戶所在的城市自動選中省市下拉選項;當咱們訪問某個大型站點時,網站程序會自動進入到用戶當前所在的城市頻道。這些功能是如何實現的呢?今天咱們來經過實例講解如何根據IP定位用戶所在城市信息。javascript
新浪提供了開放的IP地址庫數據供開發者調用,調用地址:http://int.dpool.sina.com.cn/iplookup/iplookup.php,便可返回當前ip所在的省市信息。php
咱們結合本站helloweba文章:基於jQuery+JSON的省市聯動效果中的省市下拉插件,來定位當前用戶所在的省市,即默認狀態選中的是當前用戶所在的省市。html
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript" src="js/jquery.cityselect.js"></script>
<script type="text/javascript" src="http://int.dpool.sina.com.cn/iplookup/iplookup.php?
format=js"></script>
咱們先載入jquery庫和cityselect城市下拉插件,而後調用新浪的IP地址庫,並以js的形式返回,固然若是你想查詢某一指定IP所在的城市信息可使用接口地址如:http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=json&ip=123.123.123.123,將參數ip值換成指定的IP地址便可。前端
本地js調用:java
var myprovince = remote_ip_info['province'];
var mycity = remote_ip_info['city']
var mydistrict = remote_ip_info['district'];
$(function(){
$("#city_1").citySelect({
prov:myprovince,
city:mycity
});
});
HTML代碼爲:mysql
<h3>調用新浪IP庫接口</h3>
<p>您所在的城市是:<script>document.write(myprovince+' '+mycity);</script></p>
<div id="city_1">
<select class="prov"></select>
<select class="city"></select>
</div>
淘寶也提供了比較權威的IP地址庫,調用地址:http://ip.taobao.com/service/getIpInfo.php?ip=123.123.123.123,返回對應IP的省市相關信息。jquery
調用方法:web
$(function(){
$.getJSON("getTaoIP.php",function(json){
var myprovince2 = json.data.region;
var mycity2 = json.data.city;
$("#city_2").html("您所在的城市是:"+myprovince2+mycity2);
});
});
getTaoIP.php用來獲取淘寶的對應IP的省市信息,返回的是json格式的數據。ajax
$ip = get_client_ip(); //獲取當前用戶的ip
$url = "http://ip.taobao.com/service/getIpInfo.php?ip=".$ip;
$data = file_get_contents($url); //調用淘寶接口獲取信息
echo $data;
get_client_ip()用來獲取本地用戶的IP地址。sql
//獲取用戶真實IP
function get_client_ip() {
if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
$ip = getenv("HTTP_CLIENT_IP");
else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"),
"unknown"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown"))
$ip = getenv("REMOTE_ADDR");
else if (isset ($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR']
&& strcasecmp($_SERVER['REMOTE_ADDR'], "unknown"))
$ip = $_SERVER['REMOTE_ADDR'];
else
$ip = "unknown";
return ($ip);
}
純真IP庫基本上每週都有更新,您能夠到各大下載網站上下載最新版本的純真IP庫。推薦天空下載地址:http://www.skycn.com/soft/14344.html
使用PHP調用純真ip庫的方法,本文不詳述,請戳這裏:http://blog.csdn.net/aaron_luchen/article/details/6637799
若是您的系統足夠強大,爲了安全穩重咱們建議您使用本地IP地址庫,目前網上有IP地址庫下載,咱們使用mysql版的ip庫,而後經過PHP讀取。
因爲IP數據量大,通常有三四十萬條數據,咱們要進行表結構索引優化。
CREATE TABLE IF NOT EXISTS `iptocity` (
`IP_Start` double(53,0) NOT NULL DEFAULT '0',
`IP_End` double(53,0) DEFAULT NULL,
`IP_Province` varchar(6) DEFAULT NULL,
`IP_City` varchar(10) DEFAULT NULL,
PRIMARY KEY (`IP_Start`),
KEY `IP_End` (`IP_End`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
調用方法:
$(function(){
$.getJSON("getIP.php",function(json){
var myprovince3 = json.province;
var mycity3 = json.city;
$("#city_3").citySelect({
prov:myprovince3,
city:mycity3
});
});
});
前端經過ajax向getIP.php發送異步請求,getIP.php讀取mysql中的IP數據,返回對應ip地址的省市信息。
include_once("connect.php");//連接數據庫
$myip = get_client_ip(); //獲取本地IP,get_client_ip()函數在上文中已給出
$ip=ip2int($myip); //轉換ip
$sql="select IP_Province,IP_City from iptocity where IP_Start<='$ip' order by IP_Start desc
limit 1";
$query = mysql_query($sql); //查詢庫
$rs = mysql_fetch_array($query);
$arr = array(
'province'=>$rs['IP_Province'],
'city'=>$rs['IP_City'],
);
echo json_encode($arr); //返回json數據
//將ip地址轉換成整型
function ip2int($ip){
list($ip1,$ip2,$ip3,$ip4)=explode(".",$ip);
return $ip1*pow(256,3)+$ip2*pow(256,2)+$ip3*256+$ip4;
}
注意咱們使用自定義函數ip2int()將IP地址轉換成整型,而不是用PHP自帶函數ip2long(),由於ip2long()有時會將ip轉換成負數,因此爲了保險使用自定義函數ip2int()。
經過上面的講解咱們知道如何獲取本地用戶的城市信息,如今咱們要根據用戶所在的城市訪問不一樣頁面。咱們以拉手網爲例,在go.php中寫入以下代碼:
$city = $d['city']; //利用上述方法得到本地城市名稱
switch($city){
case '深圳':
$cityname = 'shenzhen';
break;
case '北京':
$cityname = 'beijing';
break;
case '上海':
$cityname = 'shanghai';
break;
default:
$cityname = 'www';
break;
}
$go_url = "http://".$cityname.".lashou.com";
header("Location:".$go_url);
這樣,就能夠根據用戶所在的城市跳轉到拉手網對應的頻道頁面了。請看演示demo。