Android填坑系列:在小米系列等機型上放開定位許可權後的定位請求彈框樣本_Android

來源:互聯網
上載者:User

背景

近期因實際項目需要,在特定操作下觸發定位請求,取到使用者位置及附近位置。

問題:

經初步選型,最終決定接入百度定位,按照百度定位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及老版本的友盟一樣,提供開關介面,但失望了!

聯絡個推所謂的支援人員,對方肯定了個推在有定位許可權情況先擷取位置資訊的同時,但針對開關介面問題回答瀟洒!

但這確實影響到了使用者體驗!!

至此,困惑多日的問題終於找到原因。以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.