自从openGPS.cn站点上线了高精度IP定位功能一来,小编的的这个半成品网站居然突然小小的火爆了一下。文章原文发布在openGPS.cn博客栏目中,点击这里即可前往(https://www.opengps.cn/Share/Article/View.aspx?id=9),内容更新以原文为准

附上高精度IP定位功能体验连接:https://www.opengps.cn/Data/IP/IPHighAccuracy.aspx。上线后发现,好多人对其定位精度吓了一跳。甚至有没看懂实现原理的运营商的人跟我一顿较劲说运营商自己都没有这个数据,不相信这个是单纯通过IP实现的定位。实现原理之前已经在我的CSDN博客上有了说明(http://blog.csdn.net/cuitang1031/article/details/52787772)。

今天在这里简单的重复解释下高精度IP定位原理:运行在手机里的软件,具备了获取gps位置的能力,就可以把获取的gps坐标通过网络发送给后端服务器。因此在后端服务器,就可以维护一张表格,记录着某个IP和某个gps坐标的对照关系。

我们仔细看我简述的定位原理,可以观察到:

1,手机里的app,能获取位置数据

2,手机里的app,能够通过公网与后台服务器交互。

3,手机有可能是连接了wifi,此时所使用的是家庭宽带的网络

4,如果使用了家庭宽带网络,那么有可能这个家庭宽带的网络具备公网IP到户性质,也就是说家里的路由器获取了公网ip地址,这个地址不是192.168.xx开头,也不是10.xxx开头,还不是172.xxx开头。这时候后台所获取的ip和gps坐标,精度就非常高。最高精度定义为30m,也就是普通家用wifi最大能覆盖的圆形直径。

5,如果使用了家庭宽带网络,可能运营商IP资源不足,进行了叫做NAT转发的技术。这时候可能得到的就是10.xxx开头的一个内网地址,而真正的公网ip的位置在这个覆盖区域内的某个地方,这时候,这个手机提交的ip和gps坐标数据就有误差。而这个误差,是同一个局域网网段下的其他手机所提供,这样以来,就是覆盖一个街道,一个城市,甚至一个省的情况

6,如果手机使用的是手机卡的GPRS流量上网,则肯定是经过了NAT的网络结构。国内的运营商往往是一个省有一个IP池,随机的用来得用户的手机转发上网,这个情况,就出现了一个省单位范围的很多手机上报的ip和gps坐标的对照,平均一下,范围就非常大。

7,在说说高精度IP查不到位置的情况:没有位置服务功能的设备在这个IP下使用过。比如,openGPS.cn站点发布在阿里云的青岛节点的ECS上。站长从来没有在这台服务器使用过代理功能,流量始终是这个服务器自己所占用。这时候,因为没有这种具备获取位置功能的手机等设备上报位置,因此就查询不到结果。

​==========分割线===========

接下来再说说防御

很多人觉得这个做法有些无耻,未经用户同意。事实上,运行这种服务都是被经过了许可的,只不过往往没有人在使用前仔细去查阅“用户协议”文档。才出现了这个理解误区。

要说防御,其实不用才是最安全的。显然我这么说会被喷,因为现实生活当中,人们对手机的依赖程度已经相当高。那么怎么防御呢?有人针对百度这项服务,为了不被百度采集,直接使用技术手段修改hosts,让百度的位置服务相关的域名不能正常解析。这样虽然也是个办法,但是不提倡,因为这是有点因噎废食的做法。毕竟家里来个客人,还是很有可能连接你家wifi的,还要告诉客人说,我要修改一下你的手机,不让百度位置服务运行。显然这个做法不合实际。有人指出,可以从路由器里改造,实现这个局域网下的接入设备都不能使用百度位置服务。这样其实也不行,毕竟平常用的uber啥的,还是要调用百度服务的。百度的这项服务初衷是为了提高位置服务的体验,现在却会因为这个防御手段,连基本的百度地图都不能打开了。显然得不偿失。这里再多延伸一点:就算成功屏蔽了百度的服务,你能确保手机上其他应用没有获取你的位置?比如高德地图,腾讯地图,谷歌地图,QQ,微信等等,是个手机应用就可以实现这个【ip和gps数据】采集动作。因此完全没有必要采取彻底屏蔽百度服务的做法。

小编的观点,防御并非不可能,只是暂时没有多高的必要性,因此如果介意这个采集过程,可以针对精度几十米几百米范围的用户,尝试一下。前面说的干扰百度的域名解析,也是个解决方法,但是带来一堆问题,小编不提倡。

    ​    ​小编建议的防御方式: 1,经常重启路由器; 2,平常手机不需要使用位置服务时候,选择关闭位置功能(不仅仅是关闭GPS,还要关闭网络定位); 3,关闭小众软件的定位权限。这个防御方式有一定的针对性,如果用的是固定ip,显然毫无作用。但是小编之所以把这个办法列在最前面,主要原因在于,目前的网络结构下,联通电信这种运营商才具备足够丰富的IP资源可分配。而且IP是动态随机分配,通常情况下重启路由器就可以变更自己的IP,变化之后,手机里的位置类应用就需要依靠重新采集才能准确,而且目前小编观察到,百度的服务虽然是大数据实时建库分析,但仍然存在几个小时几天的更新周期。因此每天重启下路由器变化一下自己的公网ip,就很大程度下保护自己位置信息。如果用的是小运营航的网络,基本无需考虑这个问题,因为多数小运营商IP资源有限,基本不会提供公网IP到户的情况。就算有人拿到了你的公网IP,几千米甚至一个城市的范围也不会构成什么明显影响。

openGPS.cn - 如何防范被高精度IP定位采集数据相关推荐

  1. openGPS.cn - 基于ip的定位技术分享,高精度IP定位

    利用业余时间自己做了个网站,集成了几个第三方数据源,对比IP地址查询的功能: 普通IP定位:https://www.opengps.cn/Data/IP/IPSearch.aspx 高精度IP定位-1 ...

  2. openGPS.cn - 高精度IP定位现状分析

    2017年8月7日,百度对外彻底关闭了高精度IP定位接口,前期申请次接口的老用户,现在接口返回状态吗已变成240,也就是访问无权限.至此,高精度ip定位功能关闭. 对于此,是否以后不会再有高精度产品了 ...

  3. openGPS.cn - 高精度IP定位

    百度2016年8月份上线了新的高精度IP定位. 我刚刚做了这个功能让人体验,好多人感觉非常神奇,哈哈 原理在博客: https://www.opengps.cn/blog/View.aspx?id=1 ...

  4. php ip高精度定位,高精度IP定位

    基于第三方 API 的高精度 IP 定位 API 地址: http://api.asilu.com/geo/ 调用方式JSONP,返回数据格式当然只有JSON, 主要用在 PC 端浏览器. 手机端浏览 ...

  5. 分享个高精度IP定位

    https://www.opengps.cn/Data/IP/LocHighAcc.aspx 转载于:https://www.cnblogs.com/peterpan0707007/p/7215762 ...

  6. ip api php,记“百度高精度IP定位API“与PHP的结合

    查询自己的IP 下面是PHP的代码: header('Content-Type:text/html;charset=utf-8'); //设置本页面输出的文字编码为UTF-8 error_report ...

  7. IP定位,IP转地理位置

    1.目的 通过访问者IP地址,获取访问者真实的地理位置信息.例如访问者的IP地址为186.132.12.13,获取到访问者的地理位置信息为阿根廷 2.什么是IP定位 每个访问者访问互联网时,都会产生一 ...

  8. openGPS.cn - 关于手机号定位方面的个人理解

    原文发布于我的个人站点 openGPS.cn ,文章更新均已此源头连接为准 自从小编我做了openGPS.cn这个站点以来,虽然懒于打理,站点简陋,但是接到了不少人的咨询,是关于手机号定位方面.于是, ...

  9. Vue+高德高精度定位IP定位+高德位置经纬度货车路线规划,实现实时路线规划

    功能实现:实时获取当前位置,并规划到目的地的路线 实现思路: 1.定位当前位置,先精确定位,若精确定位失败则使用IP定位 2.渲染地图,规划路线 3.刷新当前位置,重新渲染路线规划 一.引入高德地图 ...

最新文章

  1. Openstack_SQLAlchemy_一对多关系表的多表插入实现
  2. c/c++常见面试题
  3. ios 的touch事件分析
  4. 【生活问答】武汉公积金可以在湖北其他城市用吗
  5. jquery.cookie 使用方法
  6. Psych101(part8)--Day8
  7. 用驴子拖宝马——怎样滥用结构体
  8. 关于STM32 IAP
  9. python pillow无法安装_Pillow
  10. ibatis的result标签中用select详解
  11. 小编详解网络蜘蛛的安全隐患及预防方法
  12. Linux 文件同步工具——rsync
  13. 工业控制网络通信协议概览 2020年7月27日
  14. 网吧机子dns服务器没有响应,网吧找不到的服务器dns地址
  15. 程序员面试必备软技能,值得收藏!
  16. fstream,ifstream,ofstream 详解与用法
  17. Html5--(span标签)
  18. simulink模块,提供xpctarget下驱动源码
  19. 穿搭网在线头像试衣间
  20. Ubuntu(WSL)安装3b1b的manim

热门文章

  1. android studio 找不到 Share Project(Subversion)
  2. 开发指南:BUMO 存证 JAVA 开发指南
  3. 关于 Beep、MessageBeep 和 Windows.Beep
  4. Android 10.0状态栏居中显示时间和修改时间显示样式
  5. 【HEC-RAS】模型不稳定故障排除技巧(一)
  6. css两端对齐不起作用?真正可用的CSS文字两端对齐
  7. android app性能优化大汇总(内存性能优化)
  8. 解决iPhone链接Mac时反复连接/断开
  9. 使用 Python 可以做什么?
  10. 分层图(图解+例题)