浅谈Android 6.0 运行时权限处理完全解析

来源:互联网 发布:软件开发技术培训中心 编辑:程序博客网 时间:2024/06/08 10:24

Android6.0以上开始对权限进行严格的控制,对于6.0以下的权限及在安装的时候,根据权限声明产生一个权限列表,用户只有在同意之后才能完成app的安装,造成了我们想要使用某个app,就要默默忍受其一些不必要的权限。而在6.0以后,我们可以直接安装,当app需要我们授予不恰当的权限的时候,我们可以予以拒绝。对于开发者来说就需要对运行时权限做一些判断。

新的权限机制更好的保护了用户的隐私,Google将权限分为两类,一类是Normal Permissions,这类权限一般不涉及用户隐私,是不需要用户进行授权的,比如手机震动、访问网络等;另一类是Dangerous Permission,一般是涉及到用户隐私的,需要用户进行授权,比如读取sdcard、访问通讯录等。

  • Normal Permissions如下
ACCESS_LOCATION_EXTRA_COMMANDSACCESS_NETWORK_STATEACCESS_NOTIFICATION_POLICYACCESS_WIFI_STATEBLUETOOTHBLUETOOTH_ADMINBROADCAST_STICKYCHANGE_NETWORK_STATECHANGE_WIFI_MULTICAST_STATECHANGE_WIFI_STATEDISABLE_KEYGUARDEXPAND_STATUS_BARGET_PACKAGE_SIZEINSTALL_SHORTCUTINTERNETKILL_BACKGROUND_PROCESSESMODIFY_AUDIO_SETTINGSNFCREAD_SYNC_SETTINGSREAD_SYNC_STATSRECEIVE_BOOT_COMPLETEDREORDER_TASKSREQUEST_INSTALL_PACKAGESSET_ALARMSET_TIME_ZONESET_WALLPAPERSET_WALLPAPER_HINTSTRANSMIT_IRUNINSTALL_SHORTCUTUSE_FINGERPRINTVIBRATEWAKE_LOCKWRITE_SYNC_SETTINGS
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • Dangerous Permissions:
group:android.permission-group.CONTACTS  permission:android.permission.WRITE_CONTACTS  permission:android.permission.GET_ACCOUNTS  permission:android.permission.READ_CONTACTSgroup:android.permission-group.PHONE  permission:android.permission.READ_CALL_LOG  permission:android.permission.READ_PHONE_STATE  permission:android.permission.CALL_PHONE  permission:android.permission.WRITE_CALL_LOG  permission:android.permission.USE_SIP  permission:android.permission.PROCESS_OUTGOING_CALLS  permission:com.android.voicemail.permission.ADD_VOICEMAILgroup:android.permission-group.CALENDAR  permission:android.permission.READ_CALENDAR  permission:android.permission.WRITE_CALENDARgroup:android.permission-group.CAMERA  permission:android.permission.CAMERAgroup:android.permission-group.SENSORS  permission:android.permission.BODY_SENSORSgroup:android.permission-group.LOCATION  permission:android.permission.ACCESS_FINE_LOCATION  permission:android.permission.ACCESS_COARSE_LOCATIONgroup:android.permission-group.STORAGE  permission:android.permission.READ_EXTERNAL_STORAGE  permission:android.permission.WRITE_EXTERNAL_STORAGEgroup:android.permission-group.MICROPHONE  permission:android.permission.RECORD_AUDIOgroup:android.permission-group.SMS  permission:android.permission.READ_SMS  permission:android.permission.RECEIVE_WAP_PUSH  permission:android.permission.RECEIVE_MMS  permission:android.permission.RECEIVE_SMS  permission:android.permission.SEND_SMS  permission:android.permission.READ_CELL_BROADCASTS
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42

       可以看到我们的危险权限有一组一组的,这样子有什么影响呢?当app授权了一个危险权限后,再去授权同一组下面的危险权限时会立即授权,不会再去询问。其实我们在申请权限时弹出的dialog就是授权整个组的,而不是单个危险权限,另外插上一嘴,这个dialog是不能为定制的。

运行时权限处理流程为先检查是否有此权限,没有权限就申请权限,有权限就直接操作,然后通过onRequestPermissionsResult这个方法进行权限的回调,如果dialog中允许了此权限就进行操作,没有可以做个提示来提醒用户。

介绍了权限后,那我们实际来申请权限一下:

1、在AndroidManifest中添加权限,我们以拨打电话的权限为例:

<uses-permission android:name="android.permission.CALL_PHONE" />

2、在需要用到权限的地方检查权限:

if (ActivityCompat.checkSelfPermission(getActivity(), Manifest.permission.CALL_PHONE)        != PackageManager.PERMISSION_GRANTED) {    } else {   }
3、如果没有权限就申请权限:

ActivityCompat.requestPermissions(getActivity(), new String[]{Manifest.permission.CALL_PHONE}, CALLPHONE);

所以2、3两个加起来可以这样子写先检查权限,没有权限就申请权限,有权限就直接进行拨打电话:

if (Build.VERSION.SDK_INT >= 23) {    //android 6.0权限问题    if (ActivityCompat.checkSelfPermission(getActivity(), Manifest.permission.CALL_PHONE)            != PackageManager.PERMISSION_GRANTED) {        ActivityCompat.requestPermissions(getActivity(), new String[]{Manifest.permission.CALL_PHONE}, CALLPHONE);    } else {        //拨打电话操作    }} else {    
 //拨打电话操作
}
4、处理权限的回调:

@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {    super.onRequestPermissionsResult(requestCode, permissions, grantResults);    switch (requestCode) {        case CALLPHONE:            if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {                //拨打电话操作            } else {                Toast.makeText(getActivity(), "对不起你没有同意该权限", Toast.LENGTH_LONG).show();            }            break;    }}

到了这里运行时的权限就做好了。



原创粉丝点击