Android填坑系列:在小米系列等机型上放开定位权限后的定位请求弹框示例
作者:Windstep 发布时间:2022-03-29 15:15:49
背景
近期因实际项目需要,在特定操作下触发定位请求,取到用户位置及附近位置。
问题:
经初步选型,最终决定接入百度定位,按照百度定位SDK Android文档,接入过程相对顺利。
但随后发现,在小米系列等部分机型上,进入app后会出现"正在尝试 通过网络或者卫星对您的手机进行定位"。
很影响用户体验。
解决过程:
1.Flurry的小坑
项目中引入了数个第三方SDK,主要包括Flurry,友盟,个推,百度定位SDK等。在App启动初始化及进入到首页的执行流中,主要涉及到Flurry,友盟,个推。
且通过对项目中所有引入第三方SDK JAR包中逐一搜索LocationManager,发现仅有Flurry和百度定位中含有。于是,初步定位到Flurry。去掉Flurry后,发现在此类机型上一进入app就出现定位请求弹框现场确实消失。
在Flurry官方文档上终于找到相应的开关接口:FlurryAgent.setReportLocation(boolean);此方法直接决定了Flurry是否上报用户地址位置信息,且其默认值为true。
于是,在对Flurry进行init后,直接调用FlurryAgent.setReportLocation(false); 再次测试,上述必现问题解决。
2.友盟的善良
本以为问题至此已经结束,不想在随后的使用过程中,在小米系列等机型上会不定期出现位置请求弹出框,且经过仔细核验,此时也并未触发app内自身的定位请求,且主要问题是:不定期出现,太诡异了!
网上查阅了一些资料,没有较好头绪。不过上面的Flurry解决过程给了一些思路,既然Flurry在有定位权限的情况下默认会获取地理位置信息,那么其他SDK会不会也类似呢?抱着好奇心态,看了下友盟的class文件,
发现了其中有一个方法setAutoLocation(boolean),哈,这不是跟Flurry如出一辙嘛。但是,发现一个奇怪的现象,友盟中setAutoLocation方法已经废弃。
public class MobclickAgent {
private static final String a = "input map is null";
private static final d b = new d();
public MobclickAgent() {
}
/** @deprecated */
public static void setAutoLocation(boolean var0) {
}
...
}
已经废弃,且变成了一个空方法,那会不会就是友盟的霸道,在偷偷获取地理位置信息的时候甚至不给app提供开关接口呢?
此开关方法已经废弃,必有原因,终于找到了老版的此方法没有废弃的友盟SDK,比较下class文件,发现老版的友盟SDK中存在LocationManager方法,但新版已经没有了。且友盟论坛上也有人说到了此问题,且去掉友盟后,
大量测试后发现此问题确实存在,看样子友盟还是很善良的,直接去掉了获取用户定位信息,所以此开关方法当然废弃了。
3.百度定位的疑惑
百度定位SDK文档中要求具有定位权限
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
实际上,具有ACCESS_FINE_LOCATION权限也就具有了ACCESS_COARSE_LOCATION权限。大量测试结果表明,当手机上GPS开启时,定位弹出框出现概率较大,且百度定位是采用混合定位方式,项目中的实际需求无需精确定位,
粗略定位已经可以满足需求,那么会不会跟权限有些关系,于是将ACCESS_FINE_LOCATION改成ACCESS_COARSE_LOCATION,且通过与其他app反解后横向对比,发现其他使用百度定位的app也只是使用了粗略定位权限,果断改之。
改后发现定位弹框不定期出现概率果然降低。
百度定位配置中还有如下Service配置
<!--百度定位服务-->
<service
android:name="com.baidu.location.f"
android:enabled="true"
android:process=":remote" >
</service>
实际测试中,发现如果权限是ACCESS_FINE_LOCATION,此处Service配置上加上android:exported="false"也一定程度上使得定位弹框出现概率降低,
此处果断加上。
<!--百度定位服务-->
<service
android:name="com.baidu.location.f"
android:enabled="true"
android:exported="false"
android:process=":remote" >
</service>
4.个推的坑货
上述修改后,不定期出现位置请求弹框概率相对已经较小。在长时间使用中偶有一次。那这定位请求到底是谁触发的呢?大量测试下,发现当修改系统时间后,此问题变成必现。
既然找到了一个蹊跷的必现路径,就好定位了许多。果断去掉百度定位,友盟及Flurry。但保留定位权限,此问题在上述必现路径下依然必现。
去掉个推初始化等相关,此问题在上述必现路径下果断消失。发现就你了,个推!!
本以为有些善良的你应该和Flurry及老版本的友盟一样,提供开关接口,但失望了!
联系个推所谓的技术支持,对方肯定了个推在有定位权限情况先获取位置信息的同时,但针对开关接口问题回答潇洒!
但这确实影响到了用户体验!!
至此,困惑多日的问题终于找到原因。以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
猜你喜欢
- CSRF介绍CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click atta
- 本文实例讲述了Java获得当前时间前指定几个小时具体时间的方法。分享给大家供大家参考,具体如下:package getBeforeHourD
- springboot:接收date类型的参数今天有个postmapping方法,地址都正确,就是死活进不去,真是奇怪了。终于从日志中得出些端
- 本文将通过阅读spring源码,分析@ComponentScan注解扫描组件的原理。和@Bean注解一样,@ComponentScan注解也
- mybatis中的#和$的区别1. #将传入的数据都当成一个字符串,会对自动传入的数据加一个双引号。如:order by #user_id#
- 我在Eclipse/MyEclipse环境下都测试过了,都好使。需要2个组件,分别是: ext-4.0.2a.jsb2 spke
- 此项目使用了OpenCVSharp加载本地摄像头,多个摄像头支持切换展示,也可以展示rtsp地址。使用NuGet如下:代码如下一、创建Mai
- 本文研究的主要是Hibernate hql查询的相关内容,具体如下。HQL介绍Hibernate语言查询(Hibernate Query L
- Springboot 内置tomcat禁止不安全HTTP方法1、在tomcat的web.xml中可以配置如下内容让tomcat禁止不安全的H
- 在实际业务中,当后台数据发生变化,客户端能够实时的收到通知,而不是由用户主动的进行页面刷新才能查看,这将是一个非常人性化的设计。有没有那么一
- 本文以C#及VB.NET后端程序代码示例展示如何将HTML转为XML文件。转换时,调用Word API -Free Spire.Doc fo
- maven 打包 动态启动脚本介绍如何通过maven的环境变量动态打包, 并动态改变启动脚本中的环境参数之前都是每个环境一个启动脚本, 其实
- 一、创建web项目1、打开idea软件,点击界面上的Create New Project2、进入如下界面。选中 java Enterpris
- 本文实例讲述了C#处理Paint事件的方法。分享给大家供大家参考。具体方法如下:using System;using System.Coll
- 一、interrupt的使用特点我们先看2个线程打断的示例首先是可打断的情况:@Testpublic void interruptedTes
- String类型小数值转为Long类型数值分为小数和整数,当传入的类型为String,需要获取的类型为Long,这时候直接通过Long.va
- 一、添加数据1、在主表中添加从表数据在景点的住宿集合(Lodgings)中增加一个度假区(Resort)var dest = (from d
- 一、创建 Spring 项目接下来使用 Maven 来创建⼀个 Spring 项⽬,创建 Spring 项目和 Servlet 类似,总共分
- 在项目中经常要用到将字符串解析成Locale,但是没有一个比较好用的类。java本身提供了3个构造函数,但是实际使用过程中,需要自己解析,比
- 逆转交替合并两个链表,即从一个链表的尾指针指向另一个链表的尾指针,依次逆转交替进行合并。下面就通过实例来详细的介绍该逆转交替合并两个链表的思