android 6.0以上为了保护用户的隐私,和以往被人诟病的权限机制,确立了新的权限机制。从 Android 6.0(API 级别 23)开始,用户开始在应用运行时向其授予权限,而不是在应用安装时授予。此方法可以简化应用安装过程,因为用户在安装或更新应用时不需要授予权限。它还让用户可以对应用的功能进行更多控制;例如,用户可以选择为相机应用提供相机访问权限,而不提供设备位置的访问权限。用户可以随时进入应用的“Settings”屏幕调用权限。

谷歌将权限分两类:1.正常权限。2.危险权限。

正常权限:

  • 正常权限不会直接给用户隐私权带来风险。如果应用在其清单中列出了正常权限,系统将自动授予该权限。

危险权限:

  • 危险权限会授予应用访问用户机密数据的权限。如果您的应用在其清单中列出了正常权限,系统将自动授予该权限。如果列出了危险权限,则用户必须明确允许应用使用这些权限。

那么对于一个应用要关注的就是那些危险权限,也就是我们所说的敏感权限。下表列出来有关的危险权限。

权限名称
1.calendar
2.camera
3.contacts
4.location
5.microphone 
6.phone
7.senors
8.sms
9.storage

兼容性来说,有以下细节:

1.低于API23 也就是系统6.0以下的,在manifest中注册申明权限清单,则自动授予权限,但是用户可以去设置中心关闭权限,但是不会引起应用运行异常

2.API23系统6.0以上的,需要在使用的时候去申请,没有申请就去使用则会引起应用运行异常。权限失效会导致 SecurityException 。

3.一开始是6.0以下系统应用,做了动态权限以后,会自动授予原先已有的权限,如果有新增的危险权限,需要做申请。

4.一开始就做了动态权限,再换回到6.0以下编译环境,新的apk无法安装。

下面以一个流程图说明问题。

危险权限的表单如下:

申请权限的工具类如下:

package com.nfdaily.nfplus.util;

import android.Manifest;
import android.app.Activity;
import android.content.pm.PackageManager;
import android.os.Build;
import android.support.v4.app.ActivityCompat; /**
* Created by xilinch on 2017/5/3.
* 对关键的权限进行申请 calendar /camera/ contacts/location/microphone /phone/senors/sms/storage
* 增加对版本号的判断,大于等于23 (6.0)以上才进行权限的申请
*/ public class UtilRequestPermissions { /**
* 拨打电话的请求码
*/
public static final int REQUEST_CODE_CALL_PHONE = 0x9001;
/**
* 存储
*/
public static final int REQUEST_CODE_READ_EXTERNAL_STORAGE = 0x9002;
/**
* 发送短信
*/
public static final int REQUEST_CODE_SEND_SMS = 0x9003;
/**
* 传感器
*/
public static final int REQUEST_CODE_BODY_SENSORS = 0x9004;
/**
* 录音
*/
public static final int REQUEST_CODE_RECORD_AUDIO = 0x9005;
/**
* 定位
*/
public static final int REQUEST_CODE_ACCESS_COARSE_LOCATION = 0x9006;
/**
* 相机
*/
public static final int REQUEST_CODE_CAMERA = 0x9007;
/**
* 读取日历
*/
public static final int REQUEST_CODE_READ_CALENDAR = 0x9008;
/**
* 录音
*/
public static final int REQUEST_CODE_READ_CONTACTS = 0x9009;
/**
* 请求权限
* @param activity
* @param permission
* @param requestCode
*/
public static void requestPermission(Activity activity, String[] permission, int requestCode){
ActivityCompat.requestPermissions(activity, permission, requestCode); } /**
* 检查权限
* @param activity
* @param permission
* @return
*/
public static boolean checkSelfPermission(Activity activity, String permission){
boolean isGranted = ActivityCompat.checkSelfPermission(activity, permission) == PackageManager.PERMISSION_GRANTED;
return isGranted;
} /**
* 日历
* @param activity
* @param requestCode
*/
public static void requestPermissionCalendar(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){ if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.READ_CALENDAR}, REQUEST_CODE_READ_CALENDAR);
} else {
requestPermission(activity, new String[]{Manifest.permission.READ_CALENDAR}, requestCode);
}
} } /**
* 照相
* @param activity
* @param requestCode
*/
public static void requestPermissionCamera(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){ if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.CAMERA}, REQUEST_CODE_CAMERA);
} else {
requestPermission(activity, new String[]{Manifest.permission.CAMERA}, requestCode);
}
}
} /**
* 联系人
* @param activity
* @param requestCode
*/
public static void requestPermissionContacts(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){
if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.READ_CONTACTS}, REQUEST_CODE_READ_CONTACTS);
} else { requestPermission(activity, new String[]{Manifest.permission.READ_CONTACTS}, requestCode);
}
}
} /**
* 定位
* @param activity
* @param requestCode
*/
public static void requestPermissionLocation(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){ if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.ACCESS_COARSE_LOCATION}, REQUEST_CODE_ACCESS_COARSE_LOCATION);
} else { requestPermission(activity, new String[]{Manifest.permission.ACCESS_COARSE_LOCATION}, requestCode);
}
}
} /**
* 录音
* @param activity
* @param requestCode
*/
public static void requestPermissionMicrophone(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){ if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.RECORD_AUDIO}, REQUEST_CODE_RECORD_AUDIO);
} else {
requestPermission(activity, new String[]{Manifest.permission.RECORD_AUDIO}, requestCode);
}
}
} /**
* 传感器
* @param activity
* @param requestCode
*/
public static void requestPermissionSensors(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){ if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.BODY_SENSORS}, REQUEST_CODE_BODY_SENSORS);
} else { requestPermission(activity, new String[]{Manifest.permission.BODY_SENSORS}, requestCode);
}
}
} /**
* 短信
* @param activity
* @param requestCode
*/
public static void requestPermissionSms(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){ if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.SEND_SMS}, REQUEST_CODE_SEND_SMS);
} else {
requestPermission(activity, new String[]{Manifest.permission.SEND_SMS}, requestCode); }
}
} /**
* 存储
* @param activity
* @param requestCode
*/
public static void requestPermissionStorage(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){ if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, REQUEST_CODE_READ_EXTERNAL_STORAGE);
} else {
requestPermission(activity, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, requestCode);
}
}
} /**
* 电话 有关,包括READ_PHONE_STATE /CALL_PHONE /READ_CALL_LOG/WRTITE_CALL_LOG/ADD_VOICEMAIL/USE_SIP/PROCESS_OUTGOING_CALLS
* @param activity
* @param requestCode
*/
public static void requestPermissionPhone(Activity activity,int requestCode){
if(Build.VERSION.SDK_INT >= 23){
if(requestCode == 0){
requestPermission(activity, new String[]{Manifest.permission.READ_PHONE_STATE}, REQUEST_CODE_CALL_PHONE);
} else {
requestPermission(activity, new String[]{Manifest.permission.READ_PHONE_STATE}, requestCode);
}
} } }

  

在下一部分将描述项目中实际处理的情况以及对比京东和淘宝的处理方案。

android6.0动态权限处理<一>的更多相关文章

  1. Android6.0动态权限申请

    goggle在Android6.0要求部分权限需要动态申请,直接下载AndroidManifest.xml中无效 6.0权限的基本知识,以下是需要单独申请的权限,共分为9组, 每组只要有一个权限申请成 ...

  2. Android6.0动态权限申请步骤以及需要注意的一些坑

    因为工作需要,简单研究了一下Android6.0权限申请,在Google提供的sample的基础上,写了一个简单的demo.算是自己的笔记吧,可能会比较混乱,主要是方便以后查看.后期有别的问题,随时更 ...

  3. Android6.0动态申请权限那些坑--以及避免用户选择不再提示后无法获取权限的问题

    Android 6.0 为了保护用户隐私,将一些权限的申请放在了应用运行的时候去申请, 比如以往的开发中,开发人员只需要将需要的权限在清单文件中配置即可,安装后用户可以在设置中的应用信息中看到:XX应 ...

  4. Android 6.0 动态权限申请注意事项

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/uana_777/article/details/54136255 Part One 权限区分 And ...

  5. android 6.0 动态权限

    Android 6.0 动态权限: 除了要在AndroidManifest.xml中申请外,还需使用时,请求用户允许授权. 以下是需要单独申请的权限,共分为9组,每组只要有一个权限申请成功了,就默认整 ...

  6. Android 6.0动态权限(转)

    转自:http://blog.csdn.net/uana_777/article/details/54136255 Part One 权限区分 Android 6.0 为了保护用户隐私,将一些权限的申 ...

  7. Android6.0动态获取权限

    Android6.0采用新的权限模型,只有在需要权限的时候,才告知用户是否授权,是在runtime时候授权,而不是在原来安装的时候 ,同时默认情况下每次在运行时打开页面时候,需要先检查是否有所需要的权 ...

  8. Android6.0获取权限

    照着<第一行代码>打代码,然并卵,感叹技术进步的神速.最后提醒一点:IT类的书籍一定要注意出版时间!出版时间!出版时间!重要的事情说三遍 问题出在android6.0的权限获取问题上,以前 ...

  9. Android 6.0动态权限申请

    转载(Android 6.0 动态权限申请简单简洁优雅的处理方式): https://blog.csdn.net/lin_dianwei/article/details/79025324

随机推荐

  1. SQLalchemy模块用法

    安装 pip install sqlalchemy #!/usr/bin/env python # -*- coding:utf-8 -*- # 加载模块 from sqlalchemy.ext.de ...

  2. 用js获取页面颜色值怎么比较?

    一般情况下,我们通过十六进制的方式设置页面颜色值 如#64e164 但当我们通过js获取这个dom颜色值的时候,返回的值却可能不是十六进制的,所以比较的时候需要分浏览器进行 在火狐和谷歌浏览器中,返回 ...

  3. Vue.js 运行环境搭建详解(基于windows的手把手安装教学)及vue、node基础知识普及

    Vue.js 是一套构建用户界面的渐进式框架.他自身不是一个全能框架——只聚焦于视图层.因此它非常容易学习,非常容易与其它库或已有项目整合.在与相关工具和支持库一起使用时,Vue.js 也能完美地驱动 ...

  4. HTTP协议入门

    1.概述 (1)HTTP是应用层协议,是从Web服务器传输超文本到本地浏览器的传送协议,端口号为80.(2)默认情况下HTTP使用TCP,但是也可以基于以后存在的其他可靠传输协议.由于UDP无法提供可 ...

  5. CenOS http 安装与运行

    1.yum安装http [root@localhost ~]# yum install httpd -y 2.启动http服务 [root@localhost ~]# systemctl start  ...

  6. redhat 6.8 配置centos6的yum源

    1. 检查是否安装yum包[root@node1 rpms]# rpm -qa|grep yum 2. 删除自带的yum包[root@node1 rpms]# rpm -qa|grep yum|xar ...

  7. 原生js在绑定事件时不用获取id名可直接用id名绑定???

    <div id="btn"> 点击 </div> <script> btn.onclick=function(){ console.log(bt ...

  8. java.toString() ,(String),String.valueOf的区别

    在Java项目的实际开发和应用中,常常需要用到将对象转为String这一基本功能.本文将对常用的转换方法进行一个总结. 常用的方法有Object#toString(),(String)要转换的对象,S ...

  9. Spring事务管理注意小事项

    在service类前加上@Transactional,声明这个service所有方法需要事务管理.每一个业务方法开始时都会打开一个事务. Spring默认情况下会对运行期例外(RunTimeExcep ...

  10. 【Android Developers Training】 0. 序言:构建你的第一个应用

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...