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获取用户定位?看这一篇就够了

### H5 UniApp `getLocation` 出现 Geolocation Permission Denied 错误解决方案 #### 1. 权限配置调整 确保应用已请求并获得用户的地理位置权限。对于H5页面来说,这通常涉及到浏览器级别的设置。如果是在iOS设备上的Safari或其他浏览器中遇到此问题,则需特别注意浏览器的安全策略和隐私设置[^2]。 #### 2. 使用 HTTPS 协议 由于现代浏览器对地理定位API的支持仅限于安全上下文中(即通过HTTPS协议加载),因此建议将应用程序部署到支持SSL证书的服务端环境中运行[^3]。 #### 3. 替代方案 - AMap.Geolocation 插件集成 当原生的 `uni.getLocation()` 方法无法正常工作时,可以考虑引入第三方的地图服务提供商如高德地图所提供的插件来实现相同功能。具体做法如下: - 安装依赖项:按照官方文档指引安装必要的SDK文件; - 初始化实例对象:创建一个新的AMap.Geolocation类实例,并传入相应的参数选项; - 处理结果数据:监听成功的回调函数处理获取的位置信息;同时也要考虑到可能出现的各种异常情况下的相应措施[^1]。 ```javascript // 示例代码片段展示如何利用高德地图API完成定位操作 import { onMounted } from 'vue'; import AMapLoader from '@amap/amap-jsapi-loader'; export default { setup() { let map; onMounted(() => { AMapLoader.load({ "key": "<Your_Key>", // 开发者申请的应用Key "version": "2.0", "plugins": ["AMap.Geolocation"] }).then((AMap) => { var geolocation = new AMap.Geolocation({ enableHighAccuracy: true,// 是否使用高精度定位,默认:true timeout: 10000, // 超过10秒后停止定位,默认:无穷大 maximumAge: 0, // 定位结果缓存0毫秒,默认:0 convert: true // 自动偏移坐标,偏移到高德坐标系下,默认:true }); map.addControl(geolocation); geolocation.getCurrentPosition(function(status,result){ if(status=='complete'){ console.log('当前位置:', result.position); }else{ console.error('定位失败',result.info); } }) }).catch(e => { console.error(e); }); }); return {}; }, }; ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值