Android中的权限请求

Android中的权限请求,第1张

Android中的权限请求

目录
  • Android中的权限请求
    • Android中权限分类
    • Android中的动态权限
      • 概述
      • 分类
      • 请求方法
        • 官方提供的API
          • 步骤
          • 代码
        • RxPermissions框架
          • 引入依赖库
          • 声明权限
          • 申请单个权限
          • 申请多个权限
        • AndPermission
          • 引入依赖库
          • 语法
          • 申请权限(单个或多个)
    • 总结

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

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

Android中的权限请求

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

Android中权限分类
  • 普通权限

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

  • 危险权限

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

  • 特殊权限

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

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中声明,那么就会默认不授权,并不会d窗给用户选择。

    
    
  • 逻辑代码
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文件中声明。


申请单个权限
//初始化RxPermissions框架
        RxPermissions permissions = new RxPermissions(this);
        //申请权限
        permissions.request(Manifest.permission.CAMERA)
                .subscribe(new Consumer() {
                    //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() {
                    //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();
                        }
                    }
                });
AndPermission 引入依赖库
implementation 'com.yanzhenjie:permission:2.0.3'
语法

申请权限(单个或多个)
//直接使用框架
        AndPermission.with(this)
                .runtime()
   .permission(Permission.WRITE_EXTERNAL_STORAGE,Permission.CAMERA)
                //接受
                .onGranted(permissions -> {
                    Toast.makeText(MainActivity.this, "授权成功!", Toast.LENGTH_SHORT).show();
                })
                //拒绝
                .onDenied(permissions -> {
                    Toast.makeText(MainActivity.this, "授权失败!", Toast.LENGTH_SHORT).show();
                })
                //启动方法
                .start();
总结
  1. Android 6.0之前,所有权限在Manifest文件中声明赋予,用户无权 *** 作;Android 6.0之后,用户可以选择是否授予权限。
  2. 对于普通权限,无论版本,都在Manifest文件中声明即可使用。
  3. 对于危险权限,Android 6.0之后,需要用户同意赋予,才可使用,保护用户隐私。
  4. 危险权限在申请之前,一定要在Manifest文件中声明,否则会出现错误或者出现无法授权的情况。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5434144.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-11
下一篇 2022-12-11

发表评论

登录后才能评论

评论列表(0条)

保存