Android 6.0运行时权限

最近研究了一下android6.0的运行时权限(公司项目需要)我开始项目中用的很乱都是直接在需要申请权限Activity页面中直接重写requestCameraPermission和onRequestPermissionsResult()方法(为了赶项目)之后都改为封装了把权限全部封装看着也爽用着更爽O(∩_∩)O哈哈~ 最后小总结了一下。

从 Android 6.0(API 级别 23)开始,用户开始在应用运行时向其授予权限,而不是在应用安装时授予。此方法可以简化应用安装过程,因为用户在安装或更新应用时不需要授予权限。它还让用户可以对应用的功能进行更多控制;例如,用户可以选择为相机应用提供相机访问权限,而不提供设备位置的访问权限。用户可以随时进入应用的设置收到开启权限。 附官方文档 https://developer.android.com/training/permissions/requesting.html

系统权限分为两类:正常权限和危险权限:

1、Normal Permissions 正常权限不会直接给用户隐私权带来风险。如果您的应用在其清单中列出了正常权限,系统将自动授予该权限。
2、Dangerous Permission 危险权限会授予应用访问用户机密数据的权限。如果您的应用在其清单中列出了正常权限,系统将自动授予该权限。如果您列出了危险权限,则用户必须明确批准您的应用使用这些权限。这些权限申请官网上都有详细说也不是很多

Normal Permissions如下

ACCESS_LOCATION_EXTRA_COMMANDS
ACCESS_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_INSTALL_PACKAGES
SET_ALARM
SET_TIME_ZONE
SET_WALLPAPER
SET_WALLPAPER_HINTS
TRANSMIT_IR
UNINSTALL_SHORTCUT
USE_FINGERPRINT
VIBRATE
WAKE_LOCK
WRITE_SYNC_SETTINGS

Dangerous Permissions:

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

group:android.permission-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:android.permission-group.CALENDAR
  permission:android.permission.READ_CALENDAR
  permission:android.permission.WRITE_CALENDAR

group:android.permission-group.CAMERA
  permission:android.permission.CAMERA

group:android.permission-group.SENSORS
  permission:android.permission.BODY_SENSORS

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

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

group:android.permission-group.MICROPHONE
  permission:android.permission.RECORD_AUDIO

group:android.permission-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

可以通过adb shell pm list permissions -d -g进行查看。

下面就总结一下我的封装权限代码吧

正常我们项目肯定都会有自己的baseActivity吧,那么我们就把我们权限封装在自己的baseActivity中后面需要申请权限就简单了直接继承调用就可以

public class BaseActivity extends Activity {

    public static final int PERMISSION_RUNTIME_REQUESR_CODE =1 ;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        switch (requestCode) {
            case PERMISSION_RUNTIME_REQUESR_CODE:
                if (grantResults.length > 0) {
                    List<String> permissionList = new ArrayList<>();
                    for (int i = 0; i < grantResults.length; i++) {
                        int grantResult = grantResults[i];
                        String permission = permissions[i];
                        if (grantResult != PackageManager.PERMISSION_GRANTED) {
                            permissionList.add(permission);
                        }
                    }
                    if (permissionList.isEmpty()) {
                        mPermissionListener.allow();
                    }else {
                        mPermissionListener.refuse(permissionList);
                    }
                }

                break;
            default:
                break;
        }
    }

    private PermissionListener mPermissionListener;

    public void requestRuntimePermission(String[] requestPermission, PermissionListener permissionListener) {
        mPermissionListener = permissionListener;
        List<String> permissionList = new ArrayList<>();
        for (String permission : requestPermission) {
            if (ContextCompat.checkSelfPermission(this, permission) != PackageManager.PERMISSION_GRANTED) {
                permissionList.add(permission);
            }
        }
        if (permissionList.isEmpty()) {
            mPermissionListener.allow();
        } else {
            ActivityCompat.requestPermissions(this, permissionList.toArray(new String[permissionList.size()]),PERMISSION_RUNTIME_REQUESR_CODE);
        }
    }

    interface PermissionListener {
        void allow();

        void refuse(List<String> permission);
    }
}

以上代码只是我的demo列出的权限相关代码,真正的项目肯定baseActivity不会才这么点的,可以看出我代码中都写好了接口回调,直接实现接口就可以很简单的监听到权限是拒绝了还是允许了

说到封装权限我们肯定想到了既然把它当个工具用那为什么不直接封装到java类里面而是封装带activity里面去了,这里面就涉及到this,可以看见我们requestPermissions的时候需要传入this这个参数,如果封装到普通的java类中就存在一个this怎么传的问题于是我就想了一个方法就是activity管理类,在每个activity中的oncreat里面添加当前activity,在ondestroy中remove当前activity这样就很方便的管理一个activity了那做成一个工具类就很方便了,具体的代码就不贴了都一样的

/**
 * Created by Army on 2016/12/29
 */

public class ActivityCollector {

    public static List<Activity> activityCollector = new ArrayList();

    public static void addActivity(Activity activity) {
        activityCollector.add(activity);
    }

    public static void removeActivity(Activity activity) {
        activityCollector.remove(activity);
    }

    public static Activity getTopActivity() {
        if (activityCollector.isEmpty()){
            return null;
        }
        return activityCollector.get(activityCollector.size()-1);
    }
}

这篇文字只是一个小总结网上还有很多权限开源库可以直接使用的也很好用。比如 :PermissionGen、MPermissions等等,其实也可以封装在fragmen中都是可以的,有些开源库就是这么做的也挺好的。
补充:还有一个就是小米手机的特殊性,小米手机本来是有自己的权限申请的为了适配6.0以后的权限小米做了一个很巧妙地办法就是默认系统直接全部走allow()方法也就是默认让所有权限都允许然后就直接走到小米的权限系统了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值