Android6.0权限总结

/**
 * Created by Leonidas on 2018/5/14.
 * Version: V1.0
 * Description:继承了Activity,实现Android6.0的运行时权限检测,
 * 需要进行运行时权限检测的Activity可以继承这个类。
 * Others: 暂无
 * ReviseHistory(Author、Date、RevisePart): 暂无
 */

public class CheckPermissionsActivity extends AppCompatActivity {
    /**
     * 需要进行检测的权限数组
     */
    protected String[] needPermissions = {
            Manifest.permission.ACCESS_COARSE_LOCATION,
            Manifest.permission.ACCESS_FINE_LOCATION,
            Manifest.permission.WRITE_EXTERNAL_STORAGE,
            Manifest.permission.READ_EXTERNAL_STORAGE,
            Manifest.permission.READ_PHONE_STATE
    };
    //权限请求码,作为权限请求的标志
    private static final int PERMISSIONS_REQUEST_CODE = 0;

    /**
     * 判断是否需要检测,防止不停的弹框
     */
    private boolean isNeedCheck = true;

    @Override
    protected void onResume() {
        super.onResume();
        if (isSystemVersionLarge23()) {//判断系统版本是否是Android6.0以上
            if (isNeedCheck) {//如果是,则需要检测
                checkPermissions(needPermissions);
            }
        }
    }

    /**
     * 判断系统版本是否是Android6.0以上
     * @return
     */
    protected boolean isSystemVersionLarge23(){
        if (Build.VERSION.SDK_INT >= 23 && getApplicationInfo().targetSdkVersion >= 23)
            return true;
        else
            return false;
    }

    /**
     * 检查权限
     * @param permissions
     */
    private void checkPermissions(String... permissions) {
        try {
            if (isSystemVersionLarge23()) {
                /*需要请求的权限*/
                List<String> needRequestPermissions = findDeniedPermissions(permissions);
                if (null != needRequestPermissions && needRequestPermissions.size() > 0) {
                    requestPermissions(needRequestPermissions.toArray(new String[needRequestPermissions.size()]),PERMISSIONS_REQUEST_CODE);
                }
            }
        } catch (Throwable e) {
        }
    }

    /**
     * 获取权限集中需要申请权限的列表
     * @param Permissions
     * @return
     *
     */
    private List<String> findDeniedPermissions(String[]Permissions) {
        List<String> needRequestPermissionList = new ArrayList<String>();
        if (isSystemVersionLarge23()){
            try {
                for (String perm : Permissions) {
                    if (checkSelfPermission(perm) != PackageManager.PERMISSION_GRANTED
                            ||shouldShowRequestPermissionRationale(perm)) {//判断权限是否被授予
                        needRequestPermissionList.add(perm);
                    }
                }
            } catch (Throwable e) {

            }
        }
        return needRequestPermissionList;
    }

    /**
     * 检测是否所有的权限都已经授权
     * @param grantResults 授权的结果
     * @return
     */
    private boolean verifyPermissions(int[] grantResults) {
        for (int result : grantResults) {
            if (result != PackageManager.PERMISSION_GRANTED) {
                return false;
            }
        }
        return true;
    }

    /**
     *当进行权限申请,
     * 并且用户做出选择后会回调onRequestPermissionsResult这个方法,
     * 在这个方法中做相关处理。
     * @param requestCode 请求码---要与进行权限申请的requestPermissions方法中的请求码相同,作为权限请求的标志
     * @param Permissions 权限
     * @param grantResults 权限的“授权结果”
     */
    @TargetApi(23)
    public void onRequestPermissionsResult(int requestCode, String[] Permissions, int[] grantResults) {
        if (requestCode == PERMISSIONS_REQUEST_CODE) {//权限请求码
            if (!verifyPermissions(grantResults)) {//判断是否所有需要被授权的权限都被授权了
                showMissingPermissionDialog();//有其中一个权限没被授权,显示权限丢失的对话框
                isNeedCheck = false;//不需要再进行检查了
            }
        }
    }

    /**
     * 显示权限丢失的对话框
     */
    private void showMissingPermissionDialog() {
        AlertDialog.Builder builder = new AlertDialog.Builder(this);
        builder.setTitle(R.string.notifyTitle);
        builder.setMessage("当前应用缺少必要权限,\n会导致部分功能使用异常。\n\n请点击\"设置\"-\"权限\"-打开所需权限。\n\n");

        // 拒绝, 退出应用
        builder.setNegativeButton(R.string.cancel,
                new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        finish();
                    }
                });

        builder.setPositiveButton(R.string.setting,
                new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        startAppSettings();//调用系统的App设置功能
                    }
                });

        builder.setCancelable(false);

        builder.show();
    }

    /**
     *  启动应用的设置
     */
    private void startAppSettings() {
        Intent intent = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
        intent.setData(Uri.parse("package:" + getPackageName()));
        startActivity(intent);
    }

    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if(keyCode == KeyEvent.KEYCODE_BACK){//当按下键盘的回退按钮则退出Activity
            this.finish();
            return true;
        }
        return super.onKeyDown(keyCode, event);
    }

}

参考:
1.https://www.jianshu.com/p/e1ab1a179fbb
2.http://www.cnblogs.com/zqlxtt/p/4873831.html
3.https://www.jianshu.com/p/b4a8b3d4f587
4.高德地图Demo源码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Anroid6.0权限问题 apk22之后Android把一些涉及用户个人信息的权限都做了默认没有权限处理,需要用户确认才可以: 用户不需要在安装软件的时候一次性授权所有申请的权限,而是可以在软件的使用过程中再对某一项权限申请进行授权。举例说明:一款相机应用在运行时申请了地理位置定位权限,就算我拒绝了这个权限,我仍然可以使用这款应用的其他功能,不用像6.0之前无法安装它。 解决办法: ● 投机取巧 如果我们不想使用6.0或者7.0的新特性,那么我们把targetSdkVersion设置22,就可以很好的避开动态配置运行时权限。而targetSdkVersion设置为22,并不影响其在Android 6.0或7.机制上使用,因为高版本兼容低版本。 解决办法:(简单到没朋友) AndroidAcp ● Acp 为 Android check permission 缩写,此库简化Android 6.0 系统复杂的权限操作而编写。 特点 ● 支持批量权限申请,不需要重写 onRequestPermissionsResult 方法,Activity 与 Fragment 中用法一致,一句话搞定。 ● 处理权限拒绝,或勾选不再询问,导致不能正常使用功能的提示框,支持跳转设置权限界面开启权限,所有提示框文字可自定义。 ● #使用Gradle构建时添加一下依赖即可: compile 'com.mylhyl:acp:1.1.7' 怎麽用? Acp.getInstance(this).request(new AcpOptions.Builder() .setPermissions(Manifest.permission.WRITE_EXTERNAL_STORAGE , Manifest.permission.READ_PHONE_STATE , Manifest.permission.SEND_SMS) /*以下为自定义提示语、按钮文字 .setDeniedMessage() .setDeniedCloseBtn() .setDeniedSettingBtn() .setRationalMessage() .setRationalBtn()*/ .build(), new AcpListener() { @Override public void onGranted() { writeSD(); getIMEI(); } @Override public void onDenied(List permissions) { makeText(permissions.toString() + "权限拒绝"); } }); ***************************** 二維碼的使用: ZXING ● 可打开默认二维码扫描页面 ● 支持对图片Bitmap的扫描功能 ● 支持对UI的定制化操作 ● 支持对条形码的扫描功能 ● 支持生成二维码操作 ● 支持控制闪光灯开关 ● 集成默认的二维码扫描页面 在具体介绍该扫描库之前我们先看一下其具体的使用方式,看看是不是几行代码就可以集成二维码扫描的功能。 ● 在module的build.gradle中执行compile操作 compile 'cn.yipianfengye.android:zxing-library:2.1' ● 1 ● 1 ● 在Application中执行初始化操作 @Override public void onCreate() { super.onCreate(); ZXingLibrary.

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值