android 运行时权限 大家可能是熟悉了 但是权限问题一直是影响用户体验的一个非常重要的因素 你不可能之一提示让客户授权 也不可能放弃改权限 所以总的来说很是让开发者纠结 下面是我总结的一个思路 供大家参考
首先先说一下权限 权限对于我们来说分为两种 一种是直接申请就可以使用的(也叫正常权限) 第二是需要用户授权才可以使用的 (也叫危险权限) 说白了也就是一句话 只要涉及到用户的隐私 都是需要用户授权的 (ApI 23以后才开始 也就android 6.0运行时权限)
正常权限 只需要用户在安装时 同意即可
ACCESS_LOCATION_EXTRA_COMMANDSACCESS_NETWORK_STATE
ACCESS_NOTIFICATION_POLICY
ACCESS_WIFI_STATE
BLUETOOTH
BLUETOOTH_ADMIN
BROADCAST_STICKY
CHANGE_NETWORK_STATE
CHANGE_WIFI_MULTICAST_STATE
CHANGE_WIFI_STATE
DISABLE_KEYGUARD
EXPAND_STATUS_BAR
GET_PACKAGE_SIZE
INSTALL_SHORTCUT
INTERNET
KILL_BACKGROUND_PROCESSES
MODIFY_AUDIO_SETTINGS
NFC
READ_SYNC_SETTINGS
READ_SYNC_STATS
RECEIVE_BOOT_COMPLETED
REORDER_TASKS
REQUEST_IGNORE_BATTERY_OPTIMIZATIONS
REQUEST_INSTALL_PACKAGES
SET_ALARM
SET_TIME_ZONE
SET_WALLPAPER
SET_WALLPAPER_HINTS
TRANSMIT_IR
UNINSTALL_SHORTCUT
USE_FINGERPRINT
VIBRATE
WAKE_LOCK
WRITE_SYNC_SETTINGS
危险权限 需要客户运行时授权的
CALENDAR
READ_CALENDAR
WRITE_CALENDAR
CAMERA
CAMERA
CONTACTS
READ_CONTACTS
WRITE_CONTACTS
GET_ACCOUNTS
LOCATION
ACCESS_FINE_LOCATION
ACCESS_COARSE_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_EXTERNAL_STORAGE
WRITE_EXTERNAL_STORAGE
下面简单说一下思路
权限处理(获取位置信息为例)
(首先判断是否开启定位服务,如果没有开启 使用intent调用设置 此一类的权限是你必须拥有的 例如 高德地图导航 用户就必须开启GPS 定位)
第一 检查权限 提供你所要所有权限 进行检索 是否已拥有权限
ContextCompat.checkSelfPermission(context {permission})
第二 提示用户我需要此权限的理由 并检查用户是否处理了这个权限 一是拒绝 返回 ture 二是 Don’t ask again(即不再提示或者用户在设置当中手动禁止了该权限) 返回false
* 注意:当客户拒绝该权限 并且选择不提示时 你只能通过intent 提示让客户手动添加改权限 或者toast 提示客户手动开启
ActivityCompat.shouldShowRequestPermissionRationale(activity,{permission})
第三 申请用户授权
ActivityCompat.requestPermissions(activity,{permission})
第四 申请权限回调
requestCode 申请码
permissions 权限数组
grantResults 对应权限数组的状态吗 代表是否拥有该权限
onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults)
PackageManager.PERMISSION_GRANTED 已拥有该权限
PackageManager.PERMISSION_DENIED 未拥有
所以综上所述 具体流程是
* if(checkSelfPermission){// 检查是否拥有该权限 * // 进行业务操作 * }else{
* if(shouldShowRequestPermissionRationale){// 检查用户是否处理 返回true 代表用户已经拒绝 * requestPermissions // 去申请 * }else{ 返回false * toast or Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS,uri)
* 看该权限对你app 的重要程度
* }
* }
* // 申请回调 * onRequestPermissionsResult
* if(grantResults[0]==PackageManager.PERMISSION_GRANTED){
* //执行业务 * }else{
* requestPermissions // 去申请 或者 将以上流程再走一边 * }
private void showContacts() {
LocationManager service = (LocationManager) getSystemService(this.LOCATION_SERVICE);
boolean enabled = service.isProviderEnabled(service.GPS_PROVIDER);
if (enabled){// 已开启定位 // 未开启权限 if (ContextCompat.checkSelfPermission(this,Manifest.permission.ACCESS_FINE_LOCATION)!= PackageManager.PERMISSION_GRANTED||ContextCompat.checkSelfPermission(this,Manifest.permission.ACCESS_COARSE_LOCATION)!=PackageManager.PERMISSION_GRANTED){
if (ActivityCompat.shouldShowRequestPermissionRationale(this,Manifest.permission.ACCESS_FINE_LOCATION)){
ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.ACCESS_FINE_LOCATION},1000);
}else {
Uri uri =Uri.parse("package:"+getPackageName());
Intent in = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS,uri);
startActivity(in);
}
}else {// 已开启权限 // 获取位置信息 }
}else {// 未开启定位 Toast.makeText(this, "系统检测到未开启GPS定位服务", Toast.LENGTH_SHORT).show();
Intent intent = new Intent();
intent.setAction(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
startActivityForResult(intent, 1315);
}
}
//Android6.0申请权限的回调方法 @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode){
case 1000:
if (grantResults[0] == PackageManager.PERMISSION_GRANTED){
//获取位置信息 }else {
showContacts();
}
break;
}
}
本着授人以渔的态度 只展示这些代码和方法 封装希望各位自己去做 拙见而已 大家共同学习