1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > php 获取客户端位置信息_PHP中获取客户端IP地址所在的地理位置信息

php 获取客户端位置信息_PHP中获取客户端IP地址所在的地理位置信息

时间:2024-03-10 14:18:49

相关推荐

php 获取客户端位置信息_PHP中获取客户端IP地址所在的地理位置信息

如何获得该IP所在的地理位置呢?腾讯的IP分享计划(/ipaddress)和新浪的IP查询接口(http://int./iplookup/iplookup.php?format=js)很不错,能够精确到市或县一级,因此就分别使用这两个查询接口了。

腾讯网

腾讯的IP分享计划的查询接口连接是:/cgi-bin/searchip,该连接后面会带有一个get参数searchip1,即searchip1=你要查询的IP地址。采用PHP向/cgi-bin/searchip发送http get request,然后获取相应,获得相应结果后,将结果用正则表达式将需要的地理位置信息提取出来就OK了。当然,PHP发送get请求的方法有很多,我用curl来模拟http请求的方法

Curl是PHP的一个扩展,进行测试之前,先确认PHP已经加载了curl扩展。打开PHP配置文件php.ini,搜索 “extension=php_curl.dll”,将其前面的分号(;)去掉,然后重启HTTP服务器,查看phpinfo(),若能看到curl的信 息,说明PHP扩展curl成功

/*

*根据腾讯IP分享计划的地址获取IP所在地,比较精确

*/

function getIPLoc_QQ($queryIP){

$url = '/cgi-bin/searchip?searchip1='.$queryIP;

$ch = curl_init($url);

curl_setopt($ch,CURLOPT_ENCODING ,'gb2312');

curl_setopt($ch, CURLOPT_TIMEOUT, 10);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true) ; // 获取数据返回

$result = curl_exec($ch);

$result = mb_convert_encoding($result, "utf-8", "gb2312"); // 编码转换,否则乱码

curl_close($ch);

preg_match("@(.*)

@iU",$result,$ipArray);

$loc = $ipArray[1];

return $loc;

}

新浪网

新浪的IP查询接口地址是:http://int./iplookup/iplookup.php,该连接后面也带有get参数,参数ip=你要查询的IP地址,format=返回的查询结果格式。为了方便起见,返回的格式采用json,即format=json,因此,PHP出来扩展curl外,还得扩展json:

/*

*根据新浪IP查询接口获取IP所在地

*/

function getIPLoc_sina($queryIP){

$url = 'http://int./iplookup/iplookup.php?format=json&ip='.$queryIP;

$ch = curl_init($url);

//curl_setopt($ch,CURLOPT_ENCODING ,'utf8');

curl_setopt($ch, CURLOPT_TIMEOUT, 10);

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true) ; // 获取数据返回

$location = curl_exec($ch);

$location = json_decode($location);

curl_close($ch);

$loc = "";

if($location===FALSE) return "";

if (emptyempty($location->desc)) {

$loc = $location->province.$location->city.$location->district.$location->isp;

}else{

$loc = $location->desc;

}

return $loc;

}

使用getIPLoc_sina("183.37.209.57")即可得到IP地址所在的地址位置。

当然,如果显示的时候对每个IP地址都用上述函数查询一次,会很慢很慢……最好是每来一个访客访问页面的时候,就调用函数查询其IP对应的地理位置,然后存入数据库。等到显示的时候直接从数据库读取就好了,这样效率会高一些。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。