目录

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

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

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

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"};@Overrideprotected 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();}}@Overridepublic 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的观察者模式@Overridepublic 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的观察者模式@Overridepublic 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文件中声明,否则会出现错误或者出现无法授权的情况。

Android中的权限请求相关推荐

  1. android危险权限分组,Android 6.0权限请求相关及权限分组方法

    Android M(6.0)API 23后加入了权限请求设置,APP需要使用某些权限需要主动申请. 权限分为3类,一组是Normal权限,无需申请,另一组是Dangerous,需申请,然后是特殊权限, ...

  2. Android中的HTTP请求

    在Android 中发送HTTP请求的方式一般有两种,HttpURLConnection和HttpClient,下面介绍的是HttpURLConnection的使用方法. 1.定义xml文件 < ...

  3. 一个整合OkHttp 、Retrofit 、Volley 、RxJava、Novate多种开源网络框架的项目,高度的封装和集成,Android中Web网络请求一行代码解决

    一个整合OkHttp .Retrofit .Volley .RxJava.Novate多种开源网络框架的项目,高度的封装和集成,Android中Web网络请求一行代码解决 AndroidHttp 一个 ...

  4. android post方法吗,Android中使用Post请求的方法

    本文实例讲述了Android中使用Post请求的方法.分享给大家供大家参考.具体如下: 一.需要用到的场景 在jQuery中使用$.post()就可以方便的发起一个post请求,在android程序中 ...

  5. Android中各个权限详解

    在Android的设计中,资源的访问或者网络连接,要得到这些服务都需要声明其访问权限,否则将无法正常工作.在Android中这样的权限有很多种,这里将各类访问权限一一罗列出来,供大家使用时参考之用. ...

  6. Android 6.0权限请求相关及权限分组

    Android M(6.0)API 23后加入了权限请求设置,APP需要使用某些权限需要主动申请. 权限分为3类,一组是Normal权限,无需申请,另一组是Dangerous,需申请,然后是特殊权限, ...

  7. Android 中的权限

    1.权限类型 Android 将权限分为不同的类型,包括安装时权限.运行时权限和特殊权限.每种权限类型都指明了当系统授予应用该权限后,应用可以访问的受限数据范围以及应用可以执行的受限操作范围.每项权限 ...

  8. Android中的权限-中英对照

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

  9. Android中SeLinux权限 .te文件编写

    在android中添加一个LocalSocket通信,权限部分折腾了好几天,终于搞定了. 首先在root权限下使用setenforce 0命令放开selinux权限,看看需要的操作是否能成功.如果可以 ...

  10. 抓包工具Fidder详解(主要来抓取Android中app的请求)

    $*********************************************************************************************$ 博主推荐 ...

最新文章

  1. 自制机械臂,能给葡萄缝针的那种,成本1万块,网友:能把脑子开源一下?
  2. ipywidgets库包的使用教程
  3. spring项目中加载配置文件
  4. 天翼云从业认证(4.1)上云迁移实战
  5. Linux下串口编程基础
  6. 【Java反射】反射机制性能问题、反射操作泛型
  7. fasttext的基本使用 java 、python为例子
  8. 用C++流成员函数put输出单个字符
  9. Java--对象内存布局
  10. c++命名空间---namespace
  11. Linux之ssh-copy-id命令
  12. mysql获取多张表中的数据_mysql之多表查询
  13. 获取随机数的n种方法,你知道几种
  14. 如何使用python实现翻转英文句子的单词顺序
  15. qq 浏览器 android x86版,qq浏览器安卓版x86
  16. S3C2410原理图导读
  17. 基于Redis实现在线游戏积分排行榜
  18. 解决Mysql 主从或主主报1062错误
  19. 没有伞的孩子才会努力奔跑!
  20. 《网络营销》期末考试重点试题

热门文章

  1. Filter动态代理敏感词汇过滤
  2. 辽宁电信TY12008-Z_智能机顶盒2.0_S905MB_线刷固件包
  3. 【历史上的今天】8 月 14 日:新浪微博开始内测;阿塔纳索夫完成论文;登上太空的计算机病毒
  4. 看产品经理怎么用360实现Java垃圾回收!
  5. 企业年会活动常用的音频类、视频类工具软件
  6. 鸿蒙不支持PDF,华为鸿蒙 HarmonyOS IoT 应用设计文档(1).pdf
  7. java实验计算机与光盘,JAVA实验指导资料.docx
  8. YV12 and NV12
  9. 易基因|ENCODE组蛋白ChIP-seq和转录因子ChIP-seq数据标准及处理流程
  10. 在endnote中制作GB/T7714《文后参考文献著录规则》的输出格式 及 编辑Output Styles中特殊符号说明