Android許可權處理的那些事你知道多少?
最近了解了Android中許可權申請的一些情況,由於Android系統的定製,裡面還是有不少坑的,所以就係統梳理下關於Android許可權申請的技術點。
一、許可權處理分類

由上圖可以看出,主要分為四類。下表逐一介紹各類對應的一些情況。

二、動態許可權申請
雖然總的來說分為四類,但是隻需要處理一種情況,即動態申請許可權。其他三種情況,要麼預設實現,要麼系統定製,無法從程式碼角度進行調整。那麼下面先來看下那些許可權需要動態申請。
(1)許可權列表

Android6.0以上把許可權分為普通許可權和危險許可權,所以危險許可權是需要動態申請,給予使用者提示的,而危險許可權就是上表展示的內容。
看到上面的 permissions,會發現一個問題,危險許可權都是一組一組的。
分組對許可權機制的申請是有一定影響的。例如app執行在android 6.x的機器上,對於授權機制是這樣的。如果你申請某個危險的許可權,假設你的app早已被使用者授權了同一組 的某個危險許可權,那麼系統會立即授權,而不需要使用者去點選授權。比如你的app對READ_CONTACTS已經授權了,當你的app申請WRITE_CONTACTS時,系統會直接授權通過。
此外,對於申請時的彈窗上面的文字說明也是對整個許可權組的說明,而不是單個許可權。
下面介紹下Android 6.0以上 動態申請許可權所設計到的一些方法。
(2)許可權申請方法
在申請許可權先,首先要保證在AndroidManifest中寫明需要的許可權。
例如:
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
具體許可權方法詳解:

許可權申請示例
以獲取定位許可權為例。
1.點選按鈕,檢查並申請許可權
btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { if (Build.VERSION.SDK_INT >23) { if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.ACCESS_COARSE_LOCATION) == PackageManager.PERMISSION_GRANTED) { //授予許可權 getLoation(); }else{ //未獲得許可權 requestPermissions(new String[]{Manifest.permission.ACCESS_COARSE_LOCATION} ,REQUEST_CODE_LOCATION); } } } });
如果有許可權,執行獲取位置邏輯,如果沒許可權,則進行請求許可權。
2.許可權申請結果回撥
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { if (requestCode == REQUEST_CODE_LOCATION) { if (grantResults[0] == PackageManager.PERMISSION_GRANTED) { getLoation(); } else { if (shouldShowRequestPermissionRationale( Manifest.permission.ACCESS_COARSE_LOCATION)){ new AlertDialog.Builder(this) .setMessage("申請定位許可權,才能為你推送更準確的資訊") .setPositiveButton("確定", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { //申請定位許可權 requestPermissions(MainActivity.this, new String[]{Manifest.permission.ACCESS_COARSE_LOCATION}, REQUEST_CODE_LOCATION); } }).show(); } } return; } super.onRequestPermissionsResult(requestCode, permissions, grantResults); }
如果同意,執行獲取位置邏輯,如果拒絕,重寫shouldShowRequestPermissionRationale方法,返回true,向用戶彈窗給出一個獲取許可權的提示,點選後再次申請許可權。
public boolean shouldShowRequestPermissionRationale(@NonNull String permission) { if (permission.equals(Manifest.permission.ACCESS_COARSE_LOCATION) ) { return true; } else { return super.shouldShowRequestPermissionRationale(permission); } }
重寫shouldShowRequestPermissionRationale,在申請位置許可權時,返回true,給使用者解釋。
以上就是動態申請許可權的邏輯,大概流程如下:

注意:
shouldShowRequestPermissionRationale :預設情況下,不重寫該方法,在Android原生系統中,如果第二次彈出許可權申請的對話方塊,會出現“以後不再彈出”的提示框,如果使用者勾選了,你再申請許可權,則shouldShowRequestPermissionRationale返回true,意思是說要給使用者一個 解釋,告訴使用者為什麼要這個許可權。
自己是從事了七年開發的Android工程師,不少人私下問我,2019年Android進階該怎麼學,方法有沒有?
沒錯,年初我花了一個多月的時間整理出來的學習資料,希望能幫助那些想進階提升Android開發,卻又不知道怎麼進階學習的朋友。【包括高階UI、效能優化、架構師課程、NDK、Kotlin、混合式開發(ReactNative+Weex)、Flutter等架構技術資料 】,希望能幫助到您面試前的複習且找到一個好的工作,也節省大家在網上搜索資料的時間來學習。
資料獲取方式:加入Android架構交流QQ群聊:513088520 ,進群即領取資料!!!
點選連結加入群聊【Android移動架構總群】:加入群聊

資料大全