Android动态获取权限许可详解

Android 6.0以后,有些权限属于 Protected Permission
这类权限只在 AndroidManifest.xml 中声明是无法真正获取到的,还需要在代码中动态获取使权限许可,即弹出提示对话框,用户点击“允许”后,方可真正获得此权限。
在这里插入图片描述


在这里插入图片描述

1.检测APP是否有该项权限
ContextCompat.checkSelfPermission(android.content.Context context, String permission)

在这里插入图片描述
返回值,有该权限返回PERMISSION_GRANTED,没权限返回PERMISSION_DENIED
在这里插入图片描述
在这里插入图片描述

2.请求权限

在这里插入图片描述

ActivityCombat.requestPermissions(android.app.Activity activity, String[] permissions, int requestCode)

在这里插入图片描述
在这里插入图片描述

//版本判断
if (Build.VERSION.SDK_INT >= 23) {
    //检查是否拥有权限
    int checkPermission = ContextCompat.checkSelfPermission(this, permission);
    if (checkPermission != PackageManager.PERMISSION_GRANTED) {
        //弹出对话框请求权限
        ActivityCompat.requestPermissions(this, new String[]{permission}, id);
        return;
    }
}
//例子请求短信权限
 if (Build.VERSION.SDK_INT >= 23) {
     if (ContextCompat.checkSelfPermission(this, Manifest.permission.RECEIVE_SMS) != PackageManager.PERMISSION_GRANTED) {
         ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.RECEIVE_SMS}, 1);
     }
}
3.授权回调
onRequestPermissonsResult(int requestCode, String[] permissions, int[] grantResults)

在这里插入图片描述
在这里插入图片描述

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {

        switch (requestCode) {
            case 1: {
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    System.out.println("hello world");
                } else {
                    System.out.println("no");
                }
            }
        }

    }
4.Easypermissions

Easypermission库是一个简化基本的系统权限逻辑的库,可用于在Android 6.0或者更高版本上,是谷歌官方的权限简化解决方案。

  • 检查权限
public static boolean hasPermissions(android.app.Activity activity, String[] permissions);
  • 请求权限
public static void requestPermissions(android.app.Activity activity, String tip,int requestCode, String[] permissions);
  • 例子
String PERMISSION_STORAGE_MSG = "请授予权限,否则影响部分使用功能";
int REQUEST_CODE_CONTACT = 101;
String[] perms = {Manifest.permission.RECEIVE_SMS};
if (!EasyPermissions.hasPermissions(this, perms)) {
    EasyPermissions.requestPermissions(this, PERMISSION_STORAGE_MSG , REQUEST_CODE_CONTACT, perms);
}
  • 授权回调
public static void onRequestPermissionsResult(int requestCode,String[] permissions,int[] grantResults,Object receivers)
  • 实现EasyPermissions.PermissionCallbacks接口,重写两个方法
public class MainActivity extends AppCompatActivity implements EasyPermissions.PermissionCallbacks {
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
    
    /**
     * 申请成功时调用
     * @param requestCode 请求权限的唯一标识码
     * @param perms 一系列权限
     */
    @Override
    public void onPermissionsGranted(int requestCode,List<String> perms) {

    }

    /**
     * 申请拒绝时调用
     * @param requestCode 请求权限的唯一标识码
     * @param perms 一系列权限
     */
    @Override
    public void onPermissionsDenied(int requestCode,List<String> perms) {

    }
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值