H5 Geolocation API 遇到的坑及总结

记录一次开发过程中使用 Geolocation API的时候,遇到的问题

 if (navigator.geolocation)
    {
       navigator.geolocation.getCurrentPosition(function(position) {
            console.log(position.coords.latitude);
            console.log(position.coords.longitude);

          }, (e)=>{
            console.error(e);
          });
    }
    else
    {
        console.log("该浏览器不支持获取地理位置。");
    }

调试环境:手机端safari,Android 自带浏览器, PC—chrome edge Firefox

  • 在本地开发时

使用localhost访问正常获取,使用本地ip获取失败

客户端效果
safariorigin does not have permission to use geolocation service
Android*GeolocationPositionError {code: 1, message: ‘Only secure origins are allowed (see: https://goo.gl/Y0ZkNV).’}
Chrome*GeolocationPositionError {code: 1, message: ‘Only secure origins are allowed (see: https://goo.gl/Y0ZkNV).’}

本地调试只能使用localhost访问正常获取

“只有在安全来源的情况才才被允许”。错误信息里还包含了一个提示链接,我们不妨打开这个链接(https://goo.gl/Y0ZkNV)看看。原来,为了保障用户的安全,Chrome浏览器认为只有安全的来源才能开启定位服务。那什么样才算是安全的来源呢?在打开链接的页面上有这么一段话:

“Secure origins” are origins that match at least one of the following (scheme, host, port) patterns:

  • (https, *, *)
  • (wss, *, *)
  • (*, localhost, *)
  • (*, 127/8, *)
  • (*, ::1/128, *)
  • (file, *, —)
  • (chrome-extension, *, —)

This list may be incomplete, and may need to be changed. Please discuss!

大概意思是说只有包含上述列表中的schemehost或者port才会被认为是安全的来源,现在这个列表还不够完整,后续可能还会有变动,有待讨论。

  • 部署到HTTPS的域名下

在页面挂载后调用API获取经纬度,无任何交互手势

客户端效果
Edge正常
chrome[Violation] Only request geolocation information in response to a user gesture.
iphone–safariuser denied geolocation
Android正常
  1. 发起定位请求需要用户的手势来发起
  2. safari 缺少用户授权 。 在iOS,重置定位权限的操作路径是:系统-通用-还原-还原位置和隐私。

**扩展:**Google 似乎 建议 不要 在页面加载时加载地理位置:

用户对在页面加载时自动请求其位置的页面不信任或感到困惑。不是在页面加载时自动请求用户的位置,而是将请求与用户的手势联系起来,例如点击“查找靠近我的商店”按钮。确保手势清楚明确地表达了对用户位置的需要。

  • 修改代码后由用户手势获取

客户端效果
Edge正常
chromeNetwork location provider at ‘https://www.googleapis.com/’ : ERR_CONNECTION_TIMED_OUT.
safari正常
Android正常
Firefoxunknown error acquiring position
  1. Chrome、Firefox以及一些套壳浏览器接入的定位服务在国外,有较大的限制,也会造成定位失败,且失败率较高。

**总结:**使用H5的 geolocation api需要满足

  • 用户授权位置信息

  • 用户主动交互手势

  • HTTPS协议

  • 在网站中说明隐私政策,告诉用户位置信息的用途

常见错误原因

  1. 用户未授权 Geolocation permission denied
  2. 浏览器不支持定位接口 Browser not Support html5 geolocation
  3. 非HTTPS安全访问 Only secure origins are allowed
  4. 定位时间超时
  5. chrome和Firefox 可能被墙

**其他:**定位经纬时,同一位置edge和 移动端实际获取的经纬差异大。实际使用准确未知。

可根据具体场景决定是否使用H5的API,在移动端还有小程序的API

参考资料:

使用HTML5地理位置定位到城市的方法及注意事项

HTML5定位的使用,及定位失败的原因

MDN-Geolocation

扩展: 【前端探索】H5获取用户定位?看这一篇就够了

  • 16
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值