閱讀提醒
從Android6.0開始,如何實現(xiàn)在運行時請求權(quán)限
從 Android 6.0(API 級別 23)開始钧栖,用戶開始在應(yīng)用運行時向其授予權(quán)限低零,而不是在應(yīng)用安裝時授予。此方法可以簡化應(yīng)用安裝過程桐经,因為用戶在安裝或更新應(yīng)用時不需要授予權(quán)限。它還讓用戶可以對應(yīng)用的功能進行更多控制浙滤;例如阴挣,用戶可以選擇為相機應(yīng)用提供相機訪問權(quán)限,而不提供設(shè)備位置的訪問權(quán)限纺腊。
系統(tǒng)權(quán)限分為兩類:正常權(quán)限和危險權(quán)限:
- 正常權(quán)限不會直接給用戶隱私權(quán)帶來風險畔咧。如果您的應(yīng)用在其清單中列出了正常權(quán)限,系統(tǒng)將自動授予該權(quán)限揖膜。
- 危險權(quán)限會授予應(yīng)用訪問用戶機密數(shù)據(jù)的權(quán)限誓沸。如果您的應(yīng)用在其清單中列出了正常權(quán)限,系統(tǒng)將自動授予該權(quán)限壹粟。如果您列出了危險權(quán)限拜隧,則用戶必須明確批準您的應(yīng)用使用這些權(quán)限。
實現(xiàn)步驟
檢查權(quán)限 ContextCompat.checkSelfPermission
當應(yīng)用需要危險權(quán)限時趁仙,則每次執(zhí)行需要這一權(quán)限的操作時都必須檢查是否具有該權(quán)限洪添。因為用戶始終可以自由調(diào)用此權(quán)限,所以即使應(yīng)用昨天使用了相機雀费,也不能假設(shè)今天仍具有該權(quán)限干奢。通過調(diào)用 ContextCompat.checkSelfPermission() 方法,如果應(yīng)用具有此權(quán)限將返回 PackageManager.PERMISSION_GRANTED盏袄,如果應(yīng)用不具有此權(quán)限將返回 PackageManager.PERMISSION_DENIED忿峻。請求權(quán)限 ActivityCompat.requestPermissions
當檢查尚未獲取某項危險權(quán)限時薄啥,需要調(diào)用ActivityCompat.requestPermissions()方法進行請求權(quán)限。調(diào)用后將顯示一個標準的 Android 對話框逛尚,次對話框不能進行自定義垄惧。解釋為什么需要權(quán)限 ActivityCompat.shouldShowRequestPermissionRationale
如果應(yīng)用在過去拒絕了此權(quán)限請求,該方法將返回 true黑低。如果用戶在過去拒絕了此權(quán)限請求赘艳,并在權(quán)限請求系統(tǒng)對話框中選擇了 Don't ask again 選項,此方法將返回 false克握。如果設(shè)備規(guī)范禁止應(yīng)用具有該權(quán)限蕾管,此方法也會返回 false。處理權(quán)限請求響應(yīng) onRequestPermissionsResult
當應(yīng)用請求權(quán)限時菩暗,系統(tǒng)將向用戶顯示一個對話框掰曾。當用戶響應(yīng)時,系統(tǒng)將調(diào)用 onRequestPermissionsResult() 方法停团,向其傳遞用戶響應(yīng)旷坦。
Demo展示
以下通過獲取聯(lián)系人列表為例
Demo下載地址:https://github.com/JasonAnt/RequestAppPermission
public void onClickPhoneBook(View view) {
//Determine whether you have been granted a particular permissio
int checkStatus = ContextCompat.checkSelfPermission(getApplication(), Manifest.permission.READ_CONTACTS);
if (PackageManager.PERMISSION_GRANTED == checkStatus) {//you have been granted a permission
navigatePhoneBook();
} else {//you don`t have been granted a permission
//Requests permissions to be granted to this application
ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_CONTACTS}, 1001);
}
}
private void navigatePhoneBook(){
Intent intent = new Intent(Intent.ACTION_PICK, ContactsContract.Contacts.CONTENT_URI);
startActivity(intent);
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if(requestCode == 1001){
if(permissions[0].equals(Manifest.permission.READ_CONTACTS)){
if(grantResults[0] == PackageManager.PERMISSION_GRANTED){
// approve and have permission, and open then phone book
navigatePhoneBook();
}else{
//Gets whether you should show UI with rationale for requesting a permission.
boolean isShow = ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.READ_CONTACTS);
if (!isShow){//Show the UI with rationale for requesting a permission.
Toast.makeText(this, "Show the UI with rationale for requesting a permission", Toast.LENGTH_SHORT).show();
}
}
}
}
}