Android开发必知:6.0权限,官方分析

【威哥说】去年,Google升级6.0后,很重要的一点是权限的改变,到现在很多总结分析权限的文章,但是或者不太详细,或者有疏漏,下面我来给大家来总结下6.0权限的问题。

1.这个新的运行时权限仅当我们设置targetSdkVersion  23(这意味着你已经在23上测试通过了)才起作用,当然还要是M系统的手机。app在6.0之前的设备依然使用旧的权限系统。

如果app的targetSdkVersion 低于 23,那将被认为app没有用23新权限测试过,那将被继续使用旧有规则:用户在安装的时候不得不接受所有权限,安装后app就有了那些权限咯!然后app像以前一样奔跑!注意,此时用户依然可以取消已经同意的授权!用户取消授权时,android 6.0系统会警告,但这不妨碍用户取消授权。

问题又来了,这时候你的app崩溃吗?

善意的主把这事也告诉了android小组,当我们在targetSdkVersion 低于23的app调用一个需要权限的函数时,这个权限如果被用户取消授权了的话,不抛出异常。但是他将啥都不干,结果导致函数返回值是null或者0.

2.代码没有成功改为支持最新运行时权限的app,不要设置targetSdkVersion 23 发布,否则你就有麻烦了。只有当你测试过了,再改为targetSdkVersion 23 。

警告:现在你在android studio新建项目,targetSdkVersion 会自动设置为 23。如果你还没支持新运行时权限,我建议你首先把targetSdkVersion 降级到22

3.权限组:

同一组的任何一个权限被授权了,其他权限也自动被授权。例如,一旦WRITE_CONTACTS被授权了,app也有READ_CONTACTS和GET_ACCOUNTS了。

权限分组官方表格如下:

Android开发必知:6.0权限,官方分析_第1张图片
Android开发必知:6.0权限,官方分析_第2张图片

下面我们来看具体的使用方法:

1.请求要申请的权限

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){

ActivityCompat.requestPermissions(this,

new String[]{Manifest.permission.READ_EXTERNAL_STORAGE,

Manifest.permission.WRITE_EXTERNAL_STORAGE,

Manifest.permission.READ_PHONE_STATE},2);

}else {

startActivity(new Intent(this,MainActivity.class));

finish();

}

2.请求后的回调方法,根据返回的结果码执行操作

//动态权限申请后系统的回调方法

@Override

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

switch (requestCode){

case MY_PERMISSIONS_REQUEST:

for (int i = 0; i < grantResults.length; i++) {

//检查权限是否被拒绝

if (grantResults[i] == PackageManager.PERMISSION_DENIED) {

Toast.makeText(SplashActivity.this, "本应用需要申请读写sdcard权限来访问本地文件", Toast.LENGTH_SHORT).show();

return;

}

}

break;

}

Intent intent = new Intent(SplashActivity.this,MainActivity.class);

startActivity(intent);

finish();

}

3.要注意这个方法,用户允许或拒绝返回值的类型

/**

* 用户第一次拒绝后,下一次,返回true,应该提示用户为什么需要这个权限,添加说明

* 用户第二次请求权限时,用户拒绝了,并选择了不再提醒,返回false

* 设备的策略禁止当前应用获取这个权限的授权,返回false

*

* 注意:第二次请求权限时候才有选项“不再提醒”,如果用户一直拒绝,但没有选择不再提醒,下次请求权限时候,

* 会继续有不再提醒的权限

*/

@Override

public boolean shouldShowRequestPermissionRationale(String permission) {

return super.shouldShowRequestPermissionRationale(permission);

}

以上就是Google官方的权限申请方法,这里总结下实际使用时候需要的注意点:

1.只请求你需要的权限:减少请求的次数,或用intent来代替,让其他的应用来处理。

防止一次请求太多的权限或请求次数太多,用户可能对你的应用感到厌烦。

2.在应用启动的时候,最好先请求应用必须的一些权限,不是必须的,在使用的时候,才请求(如一些附带权限),需要自己整理,管理一下自己应用的权限分类:

2.1 普通权限(normal permissions):只需要在androidmanifest.xml中声明相应的权限,在安装应用时,会默认获得许可。并且用户不能修改权限许可。(只需要在AndroidManifest.xml中简单声明这些权限就好,安装时就授权。不需要每次使用 时都检查权限,而且用户不能取消以上授权。)

2.2 需要申请的权限(dangerous permissions):

2.2.1 必要权限:最好在应用启动的时候,进行请求许可的一些权限(主要是应用中主要功能需要的权限)

2.2.2 附带权限:不是应用主要功能需要的权限(如:分享图片时,需要读取应用的通讯录等等)

3.解释你的应用为什么需要这些权限:在请求之前requestPermissions().,提示用户,让用户不会感到困惑

问题持续收集与回答

小伙伴们嗨起来

你可能感兴趣的:(Android开发必知:6.0权限,官方分析)