android api23没有 requestpermissions,关于android api23以后的权限设置

最近在做个项目,遇到点小问题,需要在用到某些权限的时候,比如android手机5.0或者以上的,或者有些手机比如小米,它会需要可以检查是否已经设置了权限,让用户自己选择是否需要打开,在自己动手适配了下,最后虽然解决了问题,不过不是特别完善。

先看代码:

public void isPermissonOk(Activity activity) {

WeakReference weakReference = new WeakReference(activity);

Activity context = weakReference.get();

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

if (ContextCompat.checkSelfPermission(context, Manifest.permission.ACCESS_WIFI_STATE)

!= PackageManager.PERMISSION_GRANTED) {

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.ACCESS_WIFI_STATE},

0);

}

if (ContextCompat.checkSelfPermission(context, Manifest.permission.CHANGE_WIFI_STATE)

!= PackageManager.PERMISSION_GRANTED) {

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.CHANGE_WIFI_STATE},

0);

}

if (ContextCompat.checkSelfPermission(context, Manifest.permission.INTERNET)

!= PackageManager.PERMISSION_GRANTED) {

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.INTERNET},

0);

}

if (ContextCompat.checkSelfPermission(context, Manifest.permission.WRITE_EXTERNAL_STORAGE)

!= PackageManager.PERMISSION_GRANTED) {

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},

PermissionUtils.REQUEST_WRITE_EXTERNAL_STORAGE);

}

if (ContextCompat.checkSelfPermission(context, Manifest.permission.READ_PHONE_STATE)

!= PackageManager.PERMISSION_GRANTED) {

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.READ_PHONE_STATE},

PermissionUtils.REQUEST_READ_PHONE_STATE);

}

if (ContextCompat.checkSelfPermission(context, Manifest.permission.CAMERA)

!= PackageManager.PERMISSION_GRANTED) {

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.CAMERA},

PermissionUtils.REQUEST_CAMERA);

}

if (ContextCompat.checkSelfPermission(context, Manifest.permission.READ_EXTERNAL_STORAGE)

!= PackageManager.PERMISSION_GRANTED) {

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

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},

PermissionUtils.REQUEST_READ_EXTERNAL_STORAGE);

}

}

if (ContextCompat.checkSelfPermission(context, Manifest.permission.VIBRATE)

!= PackageManager.PERMISSION_GRANTED) {

ActivityCompat.requestPermissions(context, new String[]{Manifest.permission.VIBRATE},

0);

}

}

}

代码中我们可以对各种权限进行判断是否配置了相应的权限,然后去请求权限,系统会给你相应的弹窗。

下面附代码:因为主要是针对照相、获取个人信息有些高端手机获取不到权限,会有个回调:

@Override

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

MyLog.d("hzd", "check pe");

switch (requestCode) {

case PermissionUtils.REQUEST_CAMERA:

showCameraDialog();

break;

case PermissionUtils.REQUEST_READ_EXTERNAL_STORAGE:

case PermissionUtils.REQUEST_WRITE_EXTERNAL_STORAGE:

showReadOrWriteExDialog();

break;

case PermissionUtils.REQUEST_READ_PHONE_STATE:

showReadPhoneStateDialog();

break;

}

}

因为android 5.0以上以后,系统对于某些敏感的权限,比如相机、读写外置内存需要让用户自己去选择,为了保护用户的安全,这儿当然是google基于安全考虑,个人也觉得这样会安全些,在android手机越来越容易逆向或者获取用户信息的时候,手机的安全越来越成为个大问题。

本人属于第一次接触,之前自己本人项目因为使用的是低于23以下的版本进行去做一个假兼容,其实这个方法是很好用的,不用自己去做些控制,很好的方法,不过可能会有些弊端,23或者以上的特性可能就使用不到了,有它的好处或者弊端。

本人水平有限,用于记录自己的个人小小见证和成长吧。

再附加:

如果权限没有打开可以跳转到相应的权限设置页面去,附代码如下:

public static void getAppDetailSettingIntent(Context context) {

Intent intent = new Intent();

intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

if (Build.VERSION.SDK_INT >= 9) {

intent.setAction("android.settings.APPLICATION_DETAILS_SETTINGS");

intent.setData(Uri.fromParts("package", SMJApplication.getInstance().getPackageName(), null));

} else if (Build.VERSION.SDK_INT <= 8) {

intent.setAction(Intent.ACTION_VIEW);

intent.setClassName("com.android.settings", "com.android.settings.InstalledAppDetails");

intent.putExtra("com.android.settings.ApplicationPkgName", SMJApplication.getInstance().getPackageName());

}

SMJApplication.getInstance().startActivity(intent);

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值