作者:
June的技术总结店
Android为保护用户安全和隐私,在Android6.0系统中引入了运行时权限这个功能,用户不需要在安装软件时一次性授权所有申请的权限,而是可以在软件使用过程中再对某一项权限申请进行授权。
Android在6.0系统中把所有权限分为3类,一类是普通权限,一类是危险权限,还有一类是特殊权限,特殊权限使用的很少,不再总结。普通权限指的是不会直接威胁到用户的安全和隐私的权限,对于这部分权限申请,系统会自动帮我们进行授权,而不用用户手动去操作;危险权限则表示那些可能触及用户隐私或者对设备安全性造成影响的权限,比如获取设备联系人信息等,对于这部分权限申请,必须由用户手动点击授权才可以,否则程序无法使用相应的功能。
下面列出了Android中所有的危险权限,一共9组24个权限。
CALENDAR | READ_CALENDAR WRITE_CALENDAR |
CAMERA | CAMERA |
CONTACTS | READ_CONTACTS WRITE_CONTACTS GET_ACCOUNTS |
LOCATION | ACCESS_FINE_LOCATION aCCESS_FINE_LOCATION |
MICROPHONE | RECORD_AUDIO |
PHONE | READ_PHONE_STATE CALL_PHONE READ_CALL_LOG WRITE_CALL_LOG ADD_VOICEMAIL USE_SIP PROCESS_OUTGOING_CALLS |
SENSORS | BODY_SENSORS |
SMS | SEND_SMS RECEIVE_SMS READ_SMS RECEIVE_WAP_PUSH RECEIVE_MMS |
STORAGE | READ_EXTERVAL_STORAGE WRITE_EXTERNAL_STORAGE |
注意一下,表格中没个危险权限都属于一个权限组,我们在进行运行时权限处理时使用的是权限名,但是用户一旦同意授权了,那么该权限所对应的权限组中所有的其他权限也会同时被授权。
下面我总结一下如何在程序运行的时候申请权限。以打电话为例吧。
- if (ContextCompat.checkSelfPermission(MainActivity.this,Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED){
- ActivityCompat.requestPermissions(MainActivity.this,new String[]{Manifest.permission.CALL_PHONE},1);
- } else {
- call();//打电话
- }
- @Onverride
- public void onRequestPermissionsResult(int requestCode,String[] permission.int[] grantResults){
- switch(requestCode) {
- case 1:
- if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
- call()
- } else {
- //授权失败
- }
- break;
- default:
- }
- }
最后别忘了到AndroidManifest中去申请这个权限
我想说的是好多可能接触安卓开发不是很长时间的人不知道什么时候在清单中注册权限,什么时候不要,这里我就简单说一下。
什么时候在AndroidManifest.xml中添加权限声明:
当我们要使用一些涉及到用户设备安全性的权限时,我们可在AndroidManifest.xml中使用<uses-permission>标签来
声明权限,这样安装app的时候用户就会看到app所要求的权限,如果用户不同意,只能不安装安装包。因此在6.0系统中加入了运行时权限功能。用户不需要在安装软件的时候一次性授权所有申请的权限,可以在软件的使用过程中再对某一项权限申请进行授权。现在Android所有的权限分为两类,普通权限和危险权限。普通权限系统会自动帮我们进行授权,危险权限要在程序运行过程中手动授权(日历,相机,地理位置,传感器,SMS,存储器等权限组),这9组24个权限你可以直接在用户使用程序中动态申请授权,也要再AndroidManifest.xml中声明,而其余的普通权限只要在AndroidManifest.xml中声明就行了。