Android中的权限请求

    *   [请求方法](about:blank#_42)

    *   *   [官方提供的API](about:blank#API_44)

        *   *   [步骤](about:blank#_46)

            *   [代码](about:blank#_54)

        *   [RxPermissions框架](about:blank#RxPermissions_123)

        *   *   [引入依赖库](about:blank#_130)

            *   [声明权限](about:blank#_147)

            *   [申请单个权限](about:blank#_156)

            *   [申请多个权限](about:blank#_178)

        *   [AndPermission](about:blank#AndPermission_202)

        *   *   [引入依赖库](about:blank#_204)

            *   [语法](about:blank#_210)

            *   [申请权限(单个或多个)](about:blank#_213)

*   [总结](about:blank#_232)

不积跬步,无以至千里;不积小流,无以成江海。要沉下心来,诗和远方的路费真的很贵!

参考博客:小胡老师的博客

Android中的权限请求

============================================================================

Android 6.0以后,Android中添加了动态请求权限。

Android中权限分类


  • 普通权限

一般为那种请求数据和资源的权限,比如网络请求权限。一般不告知用户,用户也不能撤销这类权限。在Manifest中申请。

  • 危险权限

一般设计到用户隐私的权限,即为危险权限,需要动态请求。

  • 特殊权限

一般对于系统的弹窗之类的权限。

Android中的动态权限


概述

Android 6.0以后,申请危险权限,不仅要在Manifest中声明,还要调用官方提供的API主动申请。

分类

总共分为9组,每一组中的一个权限申请成功,那么整组的权限都可以使用。

  1. 访问通讯录——android.permission-group.CONTACTS

  2. 电话——android.permission-group.PHONE

  3. 日历信息——android.permission-group.CALENDAR

  4. 相机权限——android.permission-group.CAMERA

  5. 传感器——android.permission-group.SENSORS

  6. 地理位置——android.permission-group.LOCATION

  7. 存储卡——android.permission-group.STORAGE

  8. 多媒体——android.permission-group.MICROPHONE

  9. SMS——android.permission-group.SMS

请求方法

官方提供的API
步骤
  1. Manifest文件中声明需要申请的权限

  2. 判断当前的版本是否符合(大于等于Android 6.0

  3. 判断权限是否已经被授权

  4. 已授权,不再操作权限

  5. 未授权,进行权限申请

  6. 用户操作后,提示权限是否开启成功

代码
  • 声明权限

如果对于这类危险权限的申请,没有在Manifest中声明,那么就会默认不授权,并不会弹窗给用户选择。


<!-- 在外部存储设备中写入和修改数据 -->

    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />



  • 逻辑代码

public class MainActivity extends AppCompatActivity {



    private static final int REQUEST_CODE = 1;

    private static String[] PERMISSIONS_STORAGE = {"android.permission.READ_EXTERNAL_STORAGE",

            "android.permission.WRITE_EXTERNAL_STORAGE"};



    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);

        //android版本在6.0以上

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

            System.out.println("版本正确");

            checkPermission();

        }else {

            System.out.println("版本过低");

        }

    }



    private void checkPermission() {

        //权限是否已经赋予

        if (ActivityCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)

                != PackageManager.PERMISSION_GRANTED) {

            //未赋予权限,申请权限

            if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission

                    .WRITE_EXTERNAL_STORAGE)) {

                //选择不开启权限的时候,提示用户

                Toast.makeText(this, "请开通相关权限,否则无法正常使用本应用!", Toast.LENGTH_SHORT).show();

            }

            //申请权限

            ActivityCompat.requestPermissions(this, PERMISSIONS_STORAGE, REQUEST_CODE);



        } else {

            //权限已赋予

            Toast.makeText(this, "已授权成功!", Toast.LENGTH_SHORT).show();

        }

    }



    @Override

    public void onRequestPermissionsResult(int requestCode,

                                           String permissions[], int[] grantResults) {

        switch (requestCode) {

            //权限的申请结果返回

            case REQUEST_CODE: {

                if (grantResults.length > 0

                        && grantResults[0] == PackageManager.PERMISSION_GRANTED) {

                    //已授权

                    Toast.makeText(this, "授权成功!", Toast.LENGTH_SHORT).show();

                } else {

                    //未授权

                    Toast.makeText(this, "授权被拒绝!", Toast.LENGTH_SHORT).show();

                }

            }

        }

    }

}



RxPermissions框架

RxPermissions 可以简化获取权限的操作,而且内部也自动帮我们判断了版本是否需要申请权限。同时结合RxJava回调结果。

使用RxPermissions框架的最小SDK版本要大于等于14。

在这里插入图片描述

引入依赖库

allprojects {

    repositories {

        ...

        maven { url 'https://jitpack.io' }

    }

}

 

dependencies {

    implementation 'com.github.tbruyelle:rxpermissions:0.10.2'

     implementation 'io.reactivex.rxjava2:rxjava:2.0.1'

    implementation 'io.reactivex.rxjava2:rxandroid:2.0.1'

}



声明权限

危险权限的申请需要在Manifest文件中声明。


<!--相机-->

<uses-permission android:name="android.permission.CAMERA" />



申请单个权限

//初始化RxPermissions框架

        RxPermissions permissions = new RxPermissions(this);

        //申请权限

        permissions.request(Manifest.permission.CAMERA)

                .subscribe(new Consumer<Boolean>() {

                    //RxJava的观察者模式

                    @Override

                    public void accept(Boolean aBoolean)  {

                        if (aBoolean ) {

                            //接受

                            Toast.makeText(MainActivity.this, "授权成功!", Toast.LENGTH_SHORT).show();

                        }else {

                            //拒绝

                            Toast.makeText(MainActivity.this, "授权失败!", Toast.LENGTH_SHORT).show();

                        }

                    }

                });



申请多个权限
  • 和申请单个权限没区别,增加一下权限的种类即可。

//初始化RxPermissions框架

        RxPermissions permissions = new RxPermissions(this);

        //申请权限

        permissions.request(Manifest.permission.CAMERA,Manifest.permission.WRITE_CALL_LOG)

                .subscribe(new Consumer<Boolean>() {

                    //RxJava的观察者模式

                    @Override

                    public void accept(Boolean aBoolean)  {

                        if (aBoolean ) {

                            //接受

                            Toast.makeText(MainActivity.this, "授权成功!", Toast.LENGTH_SHORT).show();

                        }else {

                            //拒绝

                            Toast.makeText(MainActivity.this, "授权失败!", Toast.LENGTH_SHORT).show();

                        }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值