- Android中的权限请求
- Android中权限分类
- Android中的动态权限
- 概述
- 分类
- 请求方法
- 官方提供的API
- 步骤
- 代码
- RxPermissions框架
- 引入依赖库
- 声明权限
- 申请单个权限
- 申请多个权限
- AndPermission
- 引入依赖库
- 语法
- 申请权限(单个或多个)
- 总结
不积跬步,无以至千里;不积小流,无以成江海。要沉下心来,诗和远方的路费真的很贵!
参考博客:小胡老师的博客
Android中的权限请求在Android 6.0以后,Android中添加了动态请求权限。
Android中权限分类- 普通权限
一般为那种请求数据和资源的权限,比如网络请求权限。一般不告知用户,用户也不能撤销这类权限。在Manifest中申请。
- 危险权限
一般设计到用户隐私的权限,即为危险权限,需要动态请求。
- 特殊权限
Android中的动态权限 概述一般对于系统的d窗之类的权限。
在Android 6.0以后,申请危险权限,不仅要在Manifest中声明,还要调用官方提供的API主动申请。
分类总共分为9组,每一组中的一个权限申请成功,那么整组的权限都可以使用。
- 访问通讯录——android.permission-group.CONTACTS
- 电话——android.permission-group.PHONE
- 日历信息——android.permission-group.CALENDAR
- 相机权限——android.permission-group.CAMERA
- 传感器——android.permission-group.SENSORS
- 地理位置——android.permission-group.LOCATION
- 存储卡——android.permission-group.STORAGE
- 多媒体——android.permission-group.MICROPHONE
- SMS——android.permission-group.SMS
- 在Manifest文件中声明需要申请的权限
- 判断当前的版本是否符合(大于等于Android 6.0)
- 判断权限是否已经被授权
- 已授权,不再 *** 作权限
- 未授权,进行权限申请
- 用户 *** 作后,提示权限是否开启成功
- 声明权限
如果对于这类危险权限的申请,没有在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 ConsumerAndPermission 引入依赖库() { //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(); } } });
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();总结
- Android 6.0之前,所有权限在Manifest文件中声明赋予,用户无权 *** 作;Android 6.0之后,用户可以选择是否授予权限。
- 对于普通权限,无论版本,都在Manifest文件中声明即可使用。
- 对于危险权限,Android 6.0之后,需要用户同意赋予,才可使用,保护用户隐私。
- 危险权限在申请之前,一定要在Manifest文件中声明,否则会出现错误或者出现无法授权的情况。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)