詳解Android運(yùn)行時權(quán)限及APP適配方法
Android 6.0起,Android加強(qiáng)了權(quán)限管理,引入運(yùn)行時權(quán)限概念。對于:
1. Android 5.1(API 22)及以前版本,應(yīng)用權(quán)限必須聲明在AndroidManifest.xml中,應(yīng)用在安裝時,Android會列出其所需的所有權(quán)限供用戶確認(rèn)安裝。
2. Android 6.0(API 23)及以后版本,應(yīng)用權(quán)限必須聲明在AndroidManifest.xml中,但權(quán)限分為普通權(quán)限(Normal Permissions)和危險權(quán)限(Dangerous Permissions),以下會介紹區(qū)別:
普通權(quán)限:不會給用戶隱私帶來風(fēng)險
應(yīng)用聲明在AndroidManifest.xml,系統(tǒng)會自動授予,無需應(yīng)用申請。
危險權(quán)限:應(yīng)用訪問用戶機(jī)密數(shù)據(jù)的權(quán)限,會有風(fēng)險
1. 此權(quán)限也必須聲明在AndroidManifest.xml中
2. 此類權(quán)限屬于運(yùn)行時權(quán)限,應(yīng)用在啟動后,需執(zhí)行相關(guān)需此類權(quán)限的操作前,需調(diào)用系統(tǒng)API彈窗讓用戶授權(quán),彈窗內(nèi)容應(yīng)用不可修改。如果缺少運(yùn)行時權(quán)限(用戶未授權(quán)),那么應(yīng)用強(qiáng)行執(zhí)行操作或調(diào)用API會引起APP FC。如下:
3-10 04:47:44.274 10405 8714 8714 E AndroidRuntime: java.lang.RuntimeException: Unable to create service xxxxxx.SmsBackgroundService: java.lang.SecurityException: Permission Denial: opening provider com.android.providers.telephony.MmsSmsProvider from ProcessRecord{48bbdaa 8714:xxxxxx/u0a405} (pid=8714, uid=10405) requires android.permission.READ_SMS or android.permission.WRITE_SMS
行時權(quán)限的三種狀態(tài):允許,詢問(USER_SET),拒絕(USER_FIXED)。用戶可以在系統(tǒng)的權(quán)限管理中管理應(yīng)用的每一項(xiàng)權(quán)限的狀態(tài)。
那么,應(yīng)用該如何適配運(yùn)行時權(quán)限,其標(biāo)準(zhǔn)做法是什么?
1. 在AndroidManifest.xml列出所有所需的權(quán)限,包括普通權(quán)限和危險權(quán)限
2. 應(yīng)用啟動后,需調(diào)用所需運(yùn)行時權(quán)限的API前,先調(diào)用系統(tǒng)API,如checkSelfPermission來查詢自身是否已獲取相關(guān)權(quán)限,如已獲取,可繼續(xù)正常執(zhí)行API或后續(xù)操作等,下面用偽代碼表示:
if (checkSeflPermission(...)) { // 應(yīng)用未獲取此危險權(quán)限 if (shouldShowRequestPermissionRationale(...)) { // 用戶對此權(quán)限是拒絕狀態(tài),此時應(yīng)用可自行彈窗告知用戶,注意:如果用戶在拒絕時勾選了“不再詢問”,此方法會返回false,不再可靠,則可在onRequestPermissionsResult方法中再執(zhí)行類似以下操作 // 例如百度地圖的做法,會彈窗,告知用戶缺少相關(guān)權(quán)限,請點(diǎn)擊跳轉(zhuǎn)到設(shè)置頁面,進(jìn)行權(quán)限開啟,這也是多數(shù)應(yīng)用的標(biāo)準(zhǔn)做法 // ...... } else { // 用戶對此權(quán)限是詢問狀態(tài),應(yīng)用可調(diào)用系統(tǒng)API彈窗去申請權(quán)限,用戶操作結(jié)果可在overload方法onRequestPermissionsResult中處理 requestPermissions(...); } } else { // 已有此危險權(quán)限,后面可放心執(zhí)行相關(guān)操作 // ..... }
最后,列出所有的危險權(quán)限,注意,這里有權(quán)限組(Permission Groups)的概念,申請某個具體的權(quán)限時,系統(tǒng)在彈窗中只會告知用戶應(yīng)用所需訪問的權(quán)限組,并不會描述該具體權(quán)限。如果某個權(quán)限組中,應(yīng)用一個權(quán)限都還沒被授權(quán),則會彈窗供用戶選擇授權(quán);如果某個權(quán)限組中,應(yīng)用已被授權(quán)了其中一個權(quán)限,那么應(yīng)用再次申請同一個權(quán)限組內(nèi)其他權(quán)限時,會被自動默認(rèn)授權(quán)。
相關(guān)文章
功能強(qiáng)大的登錄界面Android實(shí)現(xiàn)代碼
這篇文章主要為大家分享了功能強(qiáng)大的登錄界面Android實(shí)現(xiàn)代碼,驗(yàn)證碼制作方法,自帶一鍵刪除功能,用戶名密碼為空時抖動提示效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10Android 基于IntentService的文件下載的示例代碼
本篇文章主要介紹了Android 基于IntentService的文件下載的示例代碼,具有一定的參考價值,有興趣的可以了解一下2017-09-09Kotlin協(xié)程Channel特點(diǎn)及使用細(xì)節(jié)詳解
這篇文章主要為大家介紹了Kotlin協(xié)程Channel特點(diǎn)及使用細(xì)節(jié)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12Android應(yīng)用開發(fā)中WebView的常用方法筆記整理
WebView即是在安卓本地應(yīng)用中打開網(wǎng)頁視圖功能,其中對于JavaScript加載的各項(xiàng)操作是重點(diǎn)和難點(diǎn),本文就為大家送上Android應(yīng)用開發(fā)中WebView的常用方法筆記整理2016-05-05Android編程基于自定義控件實(shí)現(xiàn)時鐘功能的方法
這篇文章主要介紹了Android編程基于自定義控件實(shí)現(xiàn)時鐘功能的方法,結(jié)合實(shí)例形式詳細(xì)分析了Android自定義控件的定義及時鐘功能相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-03-03android studio git 刪除已在遠(yuǎn)程倉庫的文件或文件夾方式
這篇文章主要介紹了android studio git 刪除已在遠(yuǎn)程倉庫的文件或文件夾方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04