android6.0以上权限问题

本文介绍两种Android6.0及以上版本的权限管理方案:使用AndroidAcp简化权限请求流程和利用MPermissions库通过注解处理器实现简洁的权限管理。

关于android6.0以上权限问题

方法一:使用AndroidAcp

Acp 为 Android check permission 缩写,此库简化Android 6.0 系统复杂的权限操作而编写。

1.关联
    compile 'com.mylhyl:acp:1.1.7'
2.使用如下:
            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<String> permissions) {
                            makeText(permissions.toString() + "权限拒绝");
                        }
                    });

注意事项:

在android studio环境 请求Manifest.permission.CALL_PHONE权限时,Intent不能使用带参的构造函数(Intent.ACTION_CALL),否则会编译通不过的。 由于手机厂商深度定制系统的原因,很多预料不到滴,奇怪滴问题一大堆,如checkSelfPermission永远都是PERMISSION_DENIED或PERMISSION_GRANTED

方法二:注解MPermissions

基于Annotation Processor的简单易用的处理Android M运行时权限的库

1.关联
关联方式有两种

(1)在工程的build.gradle文件中添加

    buildscript {
        dependencies {
            classpath 'com.neenbedankt.gradle.plugins:android-apt:1.4'
        }
    }

然后在module的build.gradle文件中

    apply plugin: 'com.neenbedankt.android-apt'

    dependencies {
        apt 'com.zhy:mpermission-compiler:1.0.0'
        compile 'com.zhy:mpermission-api:1.0.0'
    }

(2)直接在module.gradle文件中添加

    annotationProcessor 'com.zhy:mpermission-compiler:1.0.0'
    compile 'com.zhy:mpermission-api:1.0.0'
使用如下

    public class MainActivity extends AppCompatActivity
    {

        private Button mBtnSdcard;
        private static final int REQUECT_CODE_SDCARD = 2;

        @Override
        protected void onCreate(Bundle savedInstanceState)
        {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);

            mBtnSdcard = (Button) findViewById(R.id.id_btn_sdcard);
            mBtnSdcard.setOnClickListener(new View.OnClickListener()
            {
                @Override
                public void onClick(View v)
                {
                    MPermissions.requestPermissions(MainActivity.this, REQUECT_CODE_SDCARD, Manifest.permission.WRITE_EXTERNAL_STORAGE,
                    READ_PHONE_STATE);//多个用逗号隔开
                }
            });
        }

        @Override
        public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults)
        {
            MPermissions.onRequestPermissionsResult(this, requestCode, permissions, grantResults);
            super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        }

        @PermissionGrant(REQUECT_CODE_SDCARD)
        public void requestSdcardSuccess()
        {
            Toast.makeText(this, "GRANT ACCESS SDCARD!", Toast.LENGTH_SHORT).show();
        }

        @PermissionDenied(REQUECT_CODE_SDCARD)
        public void requestSdcardFailed()
        {
            Toast.makeText(this, "DENY ACCESS SDCARD!", Toast.LENGTH_SHORT).show();
        }
    }

3.混淆
-dontwarn com.zhy.m.**
-keep class com.zhy.m.** {*;}
-keep interface com.zhy.m.** { *; }
-keep class **$$PermissionProxy { *; }
Anroid6.0权限问题 apk22之后Android把一些涉及用户个人信息的权限都做了默认没有权限处理,需要用户确认才可以: 用户不需要在安装软件的时候一次性授权所有申请的权限,而是可以在软件的使用过程中再对某一项权限申请进行授权。举例说明:一款相机应用在运行时申请了地理位置定位权限,就算我拒绝了这个权限,我仍然可以使用这款应用的其他功能,不用像6.0之前无法安装它。 解决办法: ● 投机取巧 如果我们不想使用6.0或者7.0的新特性,那么我们把targetSdkVersion设置22,就可以很好的避开动态配置运行时权限。而targetSdkVersion设置为22,并不影响其在Android 6.0或7.机制上使用,因为高版本兼容低版本。 解决办法:(简单到没朋友) AndroidAcpAcpAndroid 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、付费专栏及课程。

余额充值