基于ip的手机地理定位

2023-05-16

现在lbs服务比较火,基本上都需要定位用户的地理信息,用户地理信息一般是通过gps来定位实现的,那么假如

用户的gps坏了,或者没有开启,那么怎么获得用户的地理信息的呢?替代的办法就是可以获得手机真实ip信息来大致获取手机用户的

大概位置,虽然不是很精确,但是在精确度不高的情况下可以临时代替一下,本文就是实现如何通过ip来定位用户的。这里主要使用获得pc端模拟手机端原理

使用工具:

地图:谷歌地图Google Maps JavaScript API V3


首先介绍一下谷歌地图定位地理信息的原理:根据经纬度查询出用户的地理信息,====gps可以获得经纬度。

也可以使用谷歌的共享地理位置信息 ,例如火狐的有http://www.mozilla.com/zh-CN/firefox/geolocation/可以体验一下共享地理信息,不过那个技术是基于w3c标准的,目前ie还不是支持。


本文要实现的:根据ip 查询获得ip的地理信息 和在地图中的显示

设计思想: 获得ip信息--->查询到ip地理位置(如杭州 北京等,这个有两种方法一种是使用ip数据库,另外一种是门户网站接口,我的另外一篇有详细介绍http://blog.csdn.net/youacai/article/details/6584969)

----->根据获得的地理信息,谷歌把他转化为经纬度---->经纬度定位

本次修改增加了弹出信息窗口和 事件监听方法(监听经纬值)还是 在地图中显示图像功能


1:获得用户ip信息

这里推荐使用腾讯的ip开放接口,地理信息比较全,获得ip信息的更详细介绍http://blog.csdn.net/youacai/article/details/6584969

这个带有查询ip功能的方法,手机获得手机端ip信息传到这个方法,获取到地理位置

//根据腾讯接口查询ip地址 function getIPLoc($queryIP){ $url = 'http://ip.qq.com/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("@<span>(.*)</span></p>@iU",$result,$ipArray); $loc = $ipArray[1]; return $loc; }

这是直接获得pc端的方法,至于手机端如何获得用户ip,网上找一下方法有很多
//方法2 直接获得客户端ip地址 function getIpPlace(){ $ip=file_get_contents("http://fw.qq.com/ipaddress"); $ip=str_replace('"',' ',$ip); $ip2=explode("(",$ip); $a=substr($ip2[1],0,-2); $b=explode(",",$a); return $b; }
2:调用谷歌地图
引入地图
<script type="text/javascript" src="http://ditu.google.com/maps/api/js?sensor=true"></script>
设置谷歌地图的参数

zoom是地图显示的缩放级数,center是地图的中心位置,maptypeid是地图的类型,address主要获取查询到的地理信息,

gecode主要是谷歌地图吧地理信息转化为经度纬度值,title主要是点击时候的名称,icon主要是锚点的背景图像,没有的话就是是默认值


<script language="javascript"> var geocoder; var map; function initialize() { geocoder = new google.maps.Geocoder(); var latlng = new google.maps.LatLng(39.9493, 116.3975); var myOptions = { zoom: 15, center: latlng, mapTypeId: google.maps.MapTypeId.ROADMAP } var address = document.getElementById("address").value; var img='http://avatar.csdn.net/B/9/A/1_youacai.jpg'; if (geocoder) { geocoder.geocode( { 'address': address}, function(results, status) { if (status == google.maps.GeocoderStatus.OK) { map.setCenter(results[0].geometry.location); var marker = new google.maps.Marker({ map: map, position: results[0].geometry.location, title:'位置', icon:img }); } }); } map = new google.maps.Map(document.getElementById("map_canvas"), myOptions); }

弹出信息窗口

content是提示信息,它支持自定义的DOM样式,监听事件了有演示

open是打开窗口,相应的close是关闭窗口

/*弹出信息窗口*/ function getInfor(map,marker,address,ln){ var infowindow = new google.maps.InfoWindow({ content: address+"\n"+ln }); infowindow.open(map,marker); }

监听事件

主要是监听鼠标对地图的操作,跟js很相似

本文演示的是点击的事件,

pixeloffset是指窗口相对应焦点的位置偏移量

google.maps.event.addListener(marker, 'click', function(event)监听点击事件,焦点是marker也就是背景图像的地方,

alert弹出对应焦点的经纬信息

备注:csdn编辑器会自动生成很多<spanstyle="white-space:pre;">,复制的时候建议删除这些

/*监听事件 经纬值*/ function addListener(marker){ var infowindow = new google.maps.InfoWindow({ content:'<div style="color:#F00"><a href="http://blog.csdn.net/youacai">php淮北<img src="http://avatar.csdn.net/B/9/A/1_youacai.jpg" width="30" height="30" alt="tt"></a> 点点试试哦</div>', pixelOffset:({width:50, height:120}) }); google.maps.event.addListener(marker, 'click', function(event) { alert("你选择的经度是:"+event.latLng.lat()+" 纬度是:"+event.latLng.lat()); infowindow.open(map,marker); }); }


放置谷歌地图的容器

<div id="map_canvas" style="width: 320px; height: 480px;"></div>


3:附带一个查询天气的接口

/*获得天气预报信息*/ <br/> <iframe src="http://weather.265.com/weather.htm" width="168" height="54" frameborder="no" border="0" marginwidth="0&quoat; marginheight="0" scrolling="no"></iframe>


下面是源码程序:[备注有人反映程序不能运行 ,经查csdn的编辑器自动在我代码判断非空的时候!empty又增加了一个empty,还会自动那个增加一些空白代码(不知道怎么回事),同学复制的时候注意把他去掉即可,另外本程序编码默认是utf8,浏览器也是utf8 哦]


<?php
//根据腾讯接口查询ip地址
function getIPLoc($queryIP){


$url = 'http://ip.qq.com/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("@<span>(.*)</span></p>@iU",$result,$ipArray);
$loc = $ipArray[1];
return $loc;
}


//方法2 直接获得客户端ip地址
function getIpPlace(){
 $ip=file_get_contents("http://fw.qq.com/ipaddress");
 $ip=str_replace('"',' ',$ip);
 $ip2=explode("(",$ip);
 $a=substr($ip2[1],0,-2);
 $b=explode(",",$a);
 return $b;
}
$ip=getIpPlace();
$address =!empty($ip['3'])? iconv('gbk','utf-8',$ip['3']):'';

//获得提交的ip信息
if($_POST){
	$ip = trim($_POST['ip']);
	$loc = trim(getIPLoc($ip));
	$locip = trim($_POST['ip']);
}else{
	$ip=getIpPlace();
	$loc =!empty($ip['3'])? iconv('gbk','utf-8',$ip['3']):'';
	$locip = iconv('gbk','utf-8',$ip['0']);
}


?>
<!--调用谷歌地图js,zoom缩放倍数,center中心,mapTypeId地图类型--> 
<script type="text/javascript" src="http://ditu.google.com/maps/api/js?sensor=true"></script> 
<script language="javascript"> 
var geocoder; 
 var map; 
 function initialize() { 
  geocoder = new google.maps.Geocoder(); 
  var latlng = new google.maps.LatLng(39.9493, 116.3975); 
  var myOptions = { 
   zoom: 15, 
   center: latlng, 
   mapTypeId: google.maps.MapTypeId.ROADMAP 
  } 
  var address = document.getElementById("address").value;
	var img='http://avatar.csdn.net/B/9/A/1_youacai.jpg';
	
  if (geocoder) { 
   geocoder.geocode( { 'address': address}, function(results, status) { 
    if (status == google.maps.GeocoderStatus.OK) {
     map.setCenter(results[0].geometry.location); 
     var marker = new google.maps.Marker({ 
       map: map, 
       position: results[0].geometry.location, 
			 title:'位置',
			 icon:img
  
     });
		  getInfor(map,marker,address,results[0].geometry.location);
		  addListener(marker)
    } 
   }); 
  } 
  map = new google.maps.Map(document.getElementById("map_canvas"), myOptions); 
 }
 
 /*弹出信息窗口*/
 function getInfor(map,marker,address,ln){
 		var infowindow = new google.maps.InfoWindow({
    	content: address+"\n"+ln
 		 });
		infowindow.open(map,marker);
		
 }
 /*监听事件 经纬值*/
 function addListener(marker){
	 var infowindow = new google.maps.InfoWindow({
    	content:'<div style="color:#F00"><a href="http://blog.csdn.net/youacai">php淮北<img src="http://avatar.csdn.net/B/9/A/1_youacai.jpg" width="30" height="30" alt="tt"></a> 点点试试哦</div>',
			pixelOffset:({width:50, height:120})
 		 });
	 	google.maps.event.addListener(marker, 'click', function(event) {
    alert("你选择的经度是:"+event.latLng.lat()+"  纬度是:"+event.latLng.lat());
	  		infowindow.open(map,marker);
  		});
	 }

 </script> 
<body οnlοad="initialize()"> <div id="map_canvas" style="width: 320px; height: 480px;"></div> <div> <form method="post" action=""> 输出ip地址:<input type="text" name="ip" value=<?php echo $locip;?>> <input type="submit" value="提交"> </form> 位置: <input type="text" id="address" size="40" value=<?php echo $loc;?> > </div> /*获得天气预报信息*/ <br/> <iframe src="http://weather.265.com/weather.htm" width="168" height="54" frameborder="no" border="0" marginwidth="0&quoat; marginheight="0" scrolling="no"></iframe> </body>


  

上面是查询前后的截图


  

  

  

  
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

基于ip的手机地理定位 的相关文章

  • java 预申请磁盘空间处理大文件

    熟悉电驴和bt的你可能经常看到这些软件可以在下载文件之初就先在硬盘上建立了一个将要下载的那个文件 xff0c 但其实里面的内容是空的 xff0c 只是预先申请了磁盘空间 xff0c 这样做的好处是可以尽可能的减少磁盘碎片 xff0c 同时可
  • 看我把firefox改造成chrome的样子

    一直很喜欢chrome的主题 xff0c 美观 xff0c 而且足够简介实用 xff0c 标题栏和菜单栏 xff0c 状态栏都干掉了 xff0c 节省了很大的空间 xff0c 尤其是对我这种小屏幕的电脑来说太棒了 昨天把firefox折腾成
  • 关于CMD(win7里)的字体

    先别骂偶 xff0c 但偶不得不首先声明特别挑剔字体是偶最大的洁癖 对windows里的命令提示符也不例外 今天不小心调了一下vim的窗口大小 xff0c 不知怎么搞的越弄越糟糕 xff0c 把cmd里原来的字体都高没有了 xff0c 只剩
  • 我用django的一个感受

    我是个python业余者 xff0c 没有做过python的项目 xff0c 最近自学python xff0c 不过遇到些困惑 xff0c 希望大大们指点 早有听说python是个很好的语言 xff0c 又早有听说python做web最好的
  • new 、 delete 、 malloc 、 free 关系

    1 new delete malloc free 关系 delete 会调用对象的析构函数 和 new 对应 free 只会释放内存 xff0c new 调用构造函数 malloc 与 free 是 C 43 43 C 语言的标准库函数 x
  • 测试Java反射效率

    测试分为3个方面 xff1a 1 实例化效率 xff1b 2 方法调用效率 xff1b 3 成员变量GET调用效率 xff1b 4 成员变量SET调用 测试环境 xff1a Windows 7 Sun Java 1 6 先写好备测试用的类
  • google reader给我带了了什么

    题记 xff1a 这篇文章是自己的有感而发 xff0c 更是写给一个特别的朋友 xff0c 希望google reader xff08 以下简称GR xff09 带给我的东西也同样可以传递给你 xff0c 传递给每个人 引文 xff1a 已
  • 终于尘埃落定,准备踏上新的旅程

    经过一个月的纠结 xff0c 等待 xff0c 谈判 xff0c 奔波 xff0c 终于今天一切都定下来了 xff0c 即将离开 xff0c 有太多太多已经告别了的和即将告别的 xff0c 有些来不及 xff0c 有些舍不得 xff0c 但
  • shortcuts in Firefox on MacOSX

    以下是firefox菜单里看不到的 xff0c 看得到就自己看看吧 xff0c 不在这里总结了 home page gt opt 43 fn 43 left 因为fn 43 left gt home left tab gt 1 ctr 43
  • 火狐扩展开发:在第三方页面插入JS脚本

    第一步 xff0c 首先在xul文件内引入执行插入脚本的JS文件 xff0c 例如 xff1a 第二步 xff0c 向第三方插入脚本的代码 xff1a var ffCreate 61 init function var appcontent
  • 多式样ProgressBar

    多式样ProgressBar 普通圆形ProgressBar 该类型进度条也就是一个表示运转的过程 xff0c 例如发送短信 xff0c 连接网络等等 xff0c 表示一个过程正在执行中 一般只要在XML布局中定义就可以了 lt progr
  • 修改Linux系統的默認連接數

    1 修改用戶進程可打開文件數限制 在Linux平台上 xff0c 無論編寫客戶端程序還是服務端程序 xff0c 在進行高並發TCP連接處理時 xff0c 最高的並發數量都要受到系統對用戶單一進程同時可打開文件數量的限制 這是因為系統為每個T
  • 详解大端模式和小端模式

    详解大端模式和小端模式 一 大端模式和小端模式的起源 关于大端小端名词的由来 xff0c 有一个有趣的故事 xff0c 来自于Jonathan Swift的 格利佛游记 xff1a Lilliput和Blefuscu这两个强国在过去的36个
  • 字符串连接(c语言实现)

    起因 今天九度刷题的时候 xff0c 发现一个不调用任何c的库函数实现字符串拼接的代码很多人写的过于复杂 xff0c 链表都用上了 xff0c 真的不至于 xff0c 只要知道字符串的最后截止符是 39 0 39 题目描述 xff1a 不借
  • STL里list、vector、queue性能差异与疑似内存泄漏问题

    最近在项目中debug退出后 xff0c VS的Output面板会输出大量内存泄漏的信息 经过排查 xff0c 居然发现是使用了std list的原因 xff01 然而通过MSDN上一些前辈的讨论 xff0c 得知List并没有真正导致内存
  • malloc/free 的使用要点

    函数malloc的原型如下 xff1a void malloc size t size 用malloc申请一块长度为length的整数类型的内存 xff0c 程序如下 xff1a int p 61 int malloc sizeof int
  • 游戏中用户点击不可达地点引起寻路循环,游戏停顿问题解决

    游戏中用户点击不可达地点引起寻路循环 xff0c 游戏停顿问题解决 通常我们在游戏中通过寻路算法来找到用户点击的地点 xff0c 再根据目标地点来进行寻路 当用户点击 一个不可到达的地点时候 xff0c 游戏会出现突然停顿现象 如上图中的X
  • Android 驱动和系统开发 2. 解析模拟器GPS模块 (原创)

    好久没有写技术博客了 xff0c 恰逢今天还感冒了 xff0c 这破天气 xff0c 晚上凉风一吹 xff0c 就感冒了 xff0c 要加强锻炼呀 好了 xff0c 废话不多说 xff0c 由于工作需要 xff0c 我要移植一个虚拟的gps
  • QoS的基本原理

    QoS的基本原理 作者 xff1a 上传时间 xff1a 2011 04 22 关键字 xff1a 网络大爬虫4 QoS专题 文 胡国华 1 前言 QoS xff08 Quality of Service xff09 是服务质量的简称 对于

随机推荐

  • Java 两个数相除,只要有小数就入一位,不舍去,即为向上去整

    向上取整用Math ceil double a 向下取整用Math floor double a 例如 xff1a System out println Math ceil 1 21 System out println Math ceil
  • NAT的双机热备方案

    一般的NAT组网中 xff0c 内网用户通过单台设备进行NAT转换访问外网 xff0c NAT设备承担了所有内外网之间的流量 xff0c 无法规避单点故障 一旦发生单点故障 xff0c 将导致内网用户无法与外网通信 随着用户对网络可靠性的要
  • 《Java TCP/IP Socket 编程 》读书笔记之十二:各章节要点

    转载请注明出处 xff1a http blog csdn net ns code article details 16118955 T CP IPSocketsinjava读书笔记 第1章 xff1a 简介 1 协议相当于相互通信的程序间达
  • 给同校大一IT新生的建议

    在论坛上看到同学院的学弟问的 xff0c 就回答了一下 打的字挺多的 xff0c 所以就发到博客上了 原文是这样子的 xff1a 我上大一 xff0c 西安二本里垫底的大学 在学校C语言学一学期感觉啥也没学到 想补补自己的编程技术 xff0
  • mysql 让空值用0补充的函数IFNULL(a,0)

    记录 xff0c 防止遗忘 xff01 sql如下 xff1a SELECT IFNULL SELECT sum EO using value FROM cq energy other as eo WHERE eo EO type 61 e
  • 解决SQLite中的 database is locked

    前些时候 xff0c 同事在站点服务端使用SQlite存储一些临时数据 xff0c 但是在多人并发的时候Sqlite会抛出异常 xff1a The database file is locked database is locked xff
  • 引用的一些规则

    引用 xff1a int amp n 61 m n相当于m的别名 xff08 绰号 xff09 xff0c 对n任何操作就是对m的操作 xff0c n既不是m的拷贝 xff0c 也不是m的指针 xff0c 其实n就是m它自己 引用的一些规则
  • photoshop中制作法线贴图

  • java统计文本中某个字符串出现的次数

    原文 xff1a java统计文本中某个字符串出现的次数源代码下载地址 xff1a http www zuidaima com share 1550463297014784 htm 统计文本中某个字符串出现的次数或字符串中指定元素出现的次数
  • GitHub上最火的Android开源项目

    摘要 xff1a 截至目前 xff0c 在GitHub 最受欢迎的开源项目 系列文章中我们已介绍了40个Android开源项目 xff0c 对于如此众多的项目 xff0c 你是Mark 和码友分享经验还是慨叹 活到老要学到老 xff1f 今
  • Android 自定义类库打包jar! 谁说不可以打包res 文件?

    我们经常会有这种需求 xff0c 自己开发一个类库jar包 xff0c 提供给别人调用 网上很多教程都是这么说 xff1a 创建一个Android project 用eclipse 的export 导出 xff0c 去掉AndroidMan
  • Android WebView开发问题及优化汇总

    我们在native与网页相结合开发的过程中 xff0c 难免会遇到关于WebView一些共通的问题 就我目前开发过程中遇到的问题以及最后得到的优化方案都将在这里列举出来 有些是老生常谈 xff0c 有些则是个人摸索得出解决方法 下面就是整理
  • malloc()和free()注意点

    1 调用free 释放内存后 xff0c 不能再去访问被释放的内存空间 该段内存被释放后 xff0c 很有可能该指针仍然指向该内存单元 xff0c 但这块内存已经不属于原来的应用程序 xff0c 此时的指针为悬挂指针 xff08 可以赋为N
  • 杰克逊

    一 个人资料 迈克尔 约瑟夫 杰克逊 xff08 Michael Jackson xff09 全 名 xff1a Michael Joseph Jackson 中译名 xff1a 迈克尔 约瑟夫 杰克逊 其他译名 xff1a 台湾译名 xf
  • 搜索引擎语法汇总

    通过搜索引擎来查找自己想要的网址或信息是最快捷的方法 xff0c 也是最佳途径 因此 xff0c 掌握基本的搜索语法及使用方法对每个冲浪者是十分重要的 搜索引擎一般是通过搜索关键词来完成自己的搜索过程 xff0c 即填入一些简单的关键词来查
  • 用C#编写的银行取款系统

    using System using System Collections Generic using System Linq using System Text namespace Inten class Data st S 61 new
  • Oracle收购Sun并不总是坏事的8大原因

    关于Oracle为什么要收购Sun已经谈论了很久 xff0c 人们不禁会问 xff0c 自由世界真会消亡 xff0c 同时产生一个垄断的数据库世界吗 xff1f 虽然回答的语气可能有点肯定 xff0c 但我们也应该记住 xff0c 这起收购
  • 构造函数为什么不能为虚函数

    虚函数采用一种虚调用的方法 虚调用是一种可以在只有部分信息的情况下工作的机制 xff0c 特别允许我们调用一个只知道接口而不知道其准确对象类型的函数 但是如果要创建一个对象 xff0c 则必须要知道对象的准确类型 xff0c 因此构造函数不
  • Linux下切换Python版本的几种方法

    Linux下切换Python版本的几种方法 参考链接 xff1a 1 https www cnblogs com feynxd p 11367806 html 2 https blog csdn net weixin 34355559 ar
  • 基于ip的手机地理定位

    现在lbs服务比较火 xff0c 基本上都需要定位用户的地理信息 xff0c 用户地理信息一般是通过gps来定位实现的 xff0c 那么假如 用户的gps坏了 xff0c 或者没有开启 xff0c 那么怎么获得用户的地理信息的呢 xff1f