目录
声明权限:应用清单中声明需要的权限 运行时请求权限:应用运行时请求用户授予权限[Android 6.0(API 级别 23)] 权限最佳做法添加方式
正常权限不会直接给用户隐私权带来风险。如在其清单中列出了正常权限,系统将自动授予该权限
危险权限会授予应用访问用户机密数据的权限。如在其清单中列出了正常权限,系统将自动授予该权限。如列出了危险权限,则用户必须明确批准您的应用使用这些权限(代码中动态添加权限)
危险权限和权限组(6.0),其他为正常权限
CALENDAR
READ_CALENDARWRITE_CALENDARCAMERA
CAMERACONTACTS
READ_CONTACTSWRITE_CONTACTSGET_ACCOUNTSLOCATION
ACCESS_FINE_LOCATIONACCESS_COARSE_LOCATIONMICROPHONE
RECORD_AUDIOPHONE
READ_PHONE_STATECALL_PHONEREAD_CALL_LOGWRITE_CALL_LOGADD_VOICEMAILUSE_SIPPROCESS_OUTGOING_CALLSSENSORS
BODY_SENSORSSMS
SEND_SMSRECEIVE_SMSREAD_SMSRECEIVE_WAP_PUSHRECEIVE_MMSSTORAGE
READ_EXTERNAL_STORAGEWRITE_EXTERNAL_STORAGE如需要添加短信权限,即在清单文件中声明 uses-permission 即可
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.snazzyapp"> <uses-permission android:name="android.permission.SEND_SMS"/> <application ...> ... </application> </manifest>大致流程
判断用户是否开启该权限
判断用户是否已经拒绝过该权限,若拒绝过,提示其开启
若第一次需要该权限,提示用户选择开启/拒绝该权限
在回调方法onRequestPermissionsResult中获取用户选择情况,并做对应处理
详细案例
private void checkPermission() { // 1. 判断用户是否开启该权限 if (ContextCompat.checkSelfPermission(this, Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) { // 2. 若用户已拒绝过该权限,返回true. 提示用户开启权限 if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.CALL_PHONE)) { Toast.makeText(this, "未获得权限哦,请到设置界面开启该权限吧...", Toast.LENGTH_SHORT).show(); // 3. 第一次使用该权限时调用以请求适当的权限,用户选择结果在onRequestPermissionsResult方法中获取 } else { ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CALL_PHONE}, MY_PERMISSIONS_REQUEST_CALL_PHONE); } } else { call(); } } // 4. 获取用户接受/拒绝权限的情况 @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { switch (requestCode) { case MY_PERMISSIONS_REQUEST_CALL_PHONE: if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { call(); } else { Toast.makeText(this, "您以选择拒绝开启打电话权限...", Toast.LENGTH_SHORT).show(); } break; default: break; } }