Android 运行时权限问题的处理

2018-07-12  本文已影响0人  nade_s

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;

        }

    }

本着授人以渔的态度 只展示这些代码和方法 封装希望各位自己去做 拙见而已 大家共同学习 

加群交流
上一篇 下一篇

猜你喜欢

热点阅读