一、許可權處理分類
由上圖可以看出,主要分為四類。下表逐一介紹各類對應的一些情況。
二、動態許可權申請
雖然總的來說分為四類,但是隻需要處理一種情況,即動態申請許可權。其他三種情況,要麼預設實現,要麼系統定製,無法從程式碼角度進行調整。那麼下面先來看下那些許可權需要動態申請。
(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,意思是說要給使用者一個 解釋,告訴使用者為什麼要這個許可權。