运行时权限

Android6.0中加入了运行时权限功能,防止应用程序滥用权限。
权限分为普通权限和危险权限,普通权限不需要用户同意,系统默认。危险权限需要用户授权。
普通权限很多,但危险权限只有几组,所以记住危险权限就行了,其它的都是普通权限
危险权限有以下的9组

group:CONTACTS
  permission:android.permission.WRITE_CONTACTS
  permission:android.permission.GET_ACCOUNTS
  permission:android.permission.READ_CONTACTS

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_VOICEMAIL

group:CALENDAR
  permission:android.permission.READ_CALENDAR
  permission:android.permission.WRITE_CALENDAR

group:CAMERA
  permission:android.permission.CAMERA

group:SENSORS
  permission:android.permission.BODY_SENSORS

group:LOCATION
  permission:android.permission.ACCESS_FINE_LOCATION
  permission:android.permission.ACCESS_COARSE_LOCATION

group:STORAGE
  permission:android.permission.READ_EXTERNAL_STORAGE
  permission:android.permission.WRITE_EXTERNAL_STORAGE

group:MICROPHONE
  permission:android.permission.RECORD_AUDIO

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

如果上面的危险权限不在运行时向用户申请权限将无法获得权限。
运行权限代码

ActivityCompat.checkSelfPermission()==PackageManager.PERMISSION_GRANTED;

判断权限是否获取,checkSelfPermission()内有两个参数,第一个是Context,第二个是String类型的权限。

ActivityCompat.requestPermissions();

向用户申请权限第一个参数是context,第二个参数为存放需求的所有权限的String类型的字符数组,第三个参数为请求码,然后需要重写方法

public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults)

当用户授权操作完成后执行此方法,第一个参数为请求码,与上面的请求码对应,第二个参数为权限的String数组,第三个参数为用户操作结果。可根据以下代码判断用户是否允许权限

grantResults.length>0 && grantResults[0]==PackageManager.PERMISSION_GRANTED

允许为true,禁止为false。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值