如何获取用户的地理位置?

Posted

技术标签:

【中文标题】如何获取用户的地理位置?【英文标题】:How to get user's geolocation? 【发布时间】:2012-08-08 12:06:54 【问题描述】:

在许多网站上,我看到打印出我当前所在的城市(例如“Hello to Berlin.”)。他们是怎么做到的?为此需要什么? 我想主要部分是这里的 javascript,但是我需要什么来为我自己的应用程序实现这样的东西? (或者是否有一些适用于 Rails 的宝石?)

另外,我还想问一件事 - 我对州列表很感兴趣(通常在选择框中),用户选择他的州(比如说德国),根据州值在另一个选择中显示德国的所有地区,选择地区后显示所选地区的各个城市。

是否有可能在任何地方获得这个庞大的州/城市/地区数据库?在我们的应用中有类似的东西会很有趣,但我不知道这些列表在哪里......

【问题讨论】:

【参考方案1】:

您需要一个支持 geolocation api 的浏览器来获取用户的位置(但是,您需要用户的同意(例如 here)才能这样做(大多数较新的浏览器支持该功能,包括 IE9+ 和大多数移动操作系统的浏览器,包括 Windows Phone 7.5+)。

你所要做的就是使用 JavaScript 来获取位置:

if (window.navigator.geolocation) 
    var failure, success;
    success = function(position) 
      console.log(position);
    ;
    failure = function(message) 
      alert('Cannot retrieve location!');
    ;
    navigator.geolocation.getCurrentPosition(success, failure, 
      maximumAge: Infinity,
      timeout: 5000
    );

positionobject 将保存用户位置的纬度和经度(但是在桌面浏览器上人口较少的区域,这可能非常不准确,因为它们没有内置 GPS 设备)。进一步解释:在莱比锡,在台式计算机上获得约 300 米的精度 - 我使用手机的 GPS 设备获得约 30 米的精度。

然后您可以继续使用Google Maps API 的坐标(请参阅here for reverse geocoding)来查找用户的位置。如果需要,有一个few gems for Rails。我从不觉得有必要使用它们,但有些人似乎喜欢它们。

关于国家/城市列表,我们曾经在项目中使用过从Geonames获得的数据,但我们需要先将其转换为我们的需要。

【讨论】:

【参考方案2】:

我发现getCurrentPosition() 经常不准确,因为它不会花费大量时间等待 GPS 获得良好的准确度。我编写了一小段模仿 getCurrentPosition() 的 JavaScript,但实际上使用手表位置并监视返回的结果,直到它们更准确为止。

它的外观如下:

navigator.geolocation.getAccurateCurrentPosition(onSuccess, onError, desiredAccuracy:20, maxWait:15000);

代码在这里 - https://github.com/gwilson/getAccurateCurrentPosition

【讨论】:

【参考方案3】:

正确的语法是:

navigator.geolocation.getCurrentPosition(successCallBack, failureCallBack);

使用:

    navigator.geolocation.getCurrentPosition(
        function(position)
            var latitude  = position.coords.latitude;
            var longitude = position.coords.longitude;
            console.log("Latitude : "+latitude+" Longitude : "+longitude);
        ,
        function()
            alert("Geo Location not supported");
        
    );         

【讨论】:

【参考方案4】:

如果你更喜欢使用 ES6 并且 promises 这里是另一个版本

function getPositionPromised() 
  function successCb(cb) 
    return position => cb(position);
  

  function errorCb(cb) 
    return () => cb('Could not retrieve geolocation');
  

  return new Promise((resolve, reject) => 
    if (window.navigator.geolocation) 
      navigator.geolocation.getCurrentPosition(successCb(resolve), errorCb(reject));
     else 
      return reject('No geolocation support');
    
  )

你可以这样使用它:

getPositionPromised()
  .then(position => /*do something with position*/)
  .catch(() => /*something went wrong*/)

【讨论】:

【参考方案5】:

互联网服务提供商会购买大量 IP 地址,因此您最有可能看到的是将您的 IP 回溯到已知的 ISP。他们有一个包含 ISP 及其在世界上的位置的数据库,因此他们可以尝试查看您来自哪里。您可以尝试使用像http://www.ipaddresslocation.org/ 这样的网站来完成您的工作。如果您环顾四周,肯定会有一个站点允许您输入 IP 并获取位置,因此您只需使用访问者的 IP 向该站点发送 POST 请求并从响应中抓取位置。

或者,您可以尝试寻找一个 ISP 数据库,该数据库具有位置以及它们已分配的 IP 范围的哪些块。您可能会找到一个有钱的,但免费的可能更难找到。 或者,查看这个免费数据库http://www.maxmind.com/app/geolite

【讨论】:

【参考方案6】:

这是另一个在 php 中查找位置的 api,

http://ipinfodb.com/ip_location_api.php

【讨论】:

【参考方案7】:

我使用 geoip.maxmind.com 已经有一段时间了,它 100% 有效。可以通过 HTTP 请求访问。

【讨论】:

以上是关于如何获取用户的地理位置?的主要内容,如果未能解决你的问题,请参考以下文章

如何获取最准确的用户位置

如何获取用户位置国家 [关闭]

获取经纬度后如何获取用户的位置

如何获取用户的位置?

如何通过华为定位API精准获取用户所在地理位置?

如何获取用户的地理位置?