Android開發之permission動態權限獲取詳解
Android開發之permission動態權限獲取,供大傢參考,具體內容如下
說明
- Android 6.0 (API 23) 之前應用的權限在安裝時全部授予,運行時應用不再需要詢問用戶。在 Android 6.0 或更高版本對權限進行瞭分類,對某些涉及到用戶隱私的權限可在運行時根據用戶的需要動態授予。這樣就不需要在安裝時被強迫同意某些權限。
- 設備系統是 Android 6.0 (API 23) 或更高版本,並且應用的 targetSdkVersion 是 23 或更高版本,則針對在 AndroidManifest.xml 中聲明的危險權限,在運行時還需要動態請求用戶授權
- 動態權限請求相關操作的API封裝在在android.support.v4包中,發起請求權限的Activity需要直接或間接繼承android.support.v4.app.FragmentActivity。
- 也可以在直接或間接繼承 android.support.v4.app.Fragment 的 Fragment 中發起權限請求。
package com.xiets.demoapp; import android.Manifest; import android.content.DialogInterface; import android.content.Intent; import android.content.pm.PackageManager; import android.net.Uri; import android.os.Bundle; import android.provider.Settings; import android.support.annotation.NonNull; import android.support.v4.app.ActivityCompat; import android.support.v4.content.ContextCompat; import android.support.v7.app.AlertDialog; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Toast; /** * 一鍵備份通訊錄 * * @author xietansheng */ public class MainActivity extends AppCompatActivity { private static final int MY_PERMISSION_REQUEST_CODE = 10000; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } /** * 點擊按鈕,將通訊錄備份保存到外部存儲器備。 * * 需要3個權限(都是危險權限): * 1. 讀取通訊錄權限; * 2. 讀取外部存儲器權限; * 3. 寫入外部存儲器權限. */ public void click(View view) { /** * 第 1 步: 檢查是否有相應的權限,根據自己需求,進行添加相應的權限 */ boolean isAllGranted = checkPermissionAllGranted( new String[] { Manifest.permission.READ_CONTACTS, Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.WRITE_EXTERNAL_STORAGE } ); // 如果這3個權限全都擁有, 則直接執行備份代碼 if (isAllGranted) { doBackup(); return; } /** * 第 2 步: 請求權限 */ // 一次請求多個權限, 如果其他有權限是已經授予的將會自動忽略掉 ActivityCompat.requestPermissions( this, new String[] { Manifest.permission.READ_CONTACTS, Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.WRITE_EXTERNAL_STORAGE }, MY_PERMISSION_REQUEST_CODE ); } /** * 檢查是否擁有指定的所有權限 */ private boolean checkPermissionAllGranted(String[] permissions) { for (String permission : permissions) { if (ContextCompat.checkSelfPermission(this, permission) != PackageManager.PERMISSION_GRANTED) { // 隻要有一個權限沒有被授予, 則直接返回 false return false; } } return true; } /** * 第 3 步: 申請權限結果返回處理 */ @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (requestCode == MY_PERMISSION_REQUEST_CODE) { boolean isAllGranted = true; // 判斷是否所有的權限都已經授予瞭 for (int grant : grantResults) { if (grant != PackageManager.PERMISSION_GRANTED) { isAllGranted = false; break; } } if (isAllGranted) { // 如果所有的權限都授予瞭, 則執行備份代碼 doBackup(); } else { // 彈出對話框告訴用戶需要權限的原因, 並引導用戶去應用權限管理中手動打開權限按鈕 openAppDetails(); } } } /** * 第 4 步: 備份通訊錄操作 */ private void doBackup() { // 本文主旨是講解如果動態申請權限, 具體備份代碼不再展示, 就假裝備份一下 Toast.makeText(this, "正在備份通訊錄...", Toast.LENGTH_SHORT).show(); } /** * 打開 APP 的詳情設置 */ private void openAppDetails() { AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setMessage("備份通訊錄需要訪問 “通訊錄” 和 “外部存儲器”,請到 “應用信息 -> 權限” 中授予!"); builder.setPositiveButton("去手動授權", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { Intent intent = new Intent(); intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS); intent.addCategory(Intent.CATEGORY_DEFAULT); intent.setData(Uri.parse("package:" + getPackageName())); intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); intent.addFlags(Intent.FLAG_ACTIVITY_NO_HISTORY); intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); startActivity(intent); } }); builder.setNegativeButton("取消", null); builder.show(); } }
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Android權限詢問的實例詳解
- Android11及以上文件讀寫權限申請詳細介紹
- Android permission denied原因歸納和解決辦法
- Android在一個app中安裝並卸載另一個app的示例代碼
- Android調用應用安裝界面方法