浅谈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如下
- 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:
- 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; }}
到了这里运行时的权限就做好了。
- 浅谈Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- Android 6.0 运行时权限处理完全解析
- 基于MPI的二维VTI介质一阶拟声波方程有限差分地震正演模拟(一维数组)
- 比特币白皮书 个人翻译+注解
- Java版的IRR(内部收益率)实现
- webservice的简单理解
- POJ 1127 Jack Straws(线段相交判断+并查集)
- 浅谈Android 6.0 运行时权限处理完全解析
- Mybatis+MySql 一个标签中执行多条sql语句
- PHP使用PHPExcel
- 安卓webview无法加载html页面
- C语言实现对字符串的逆序输出
- JSTL比较两个字符串
- 如何在Android源码编译系统中添加一个Java项目
- C#的装箱与拆箱与基本类型
- 新建的web项目的jsp页面报错的解决方法