动态申请权限的写法

本文介绍在安卓6.0及以上版本中如何实现动态权限申请的方法,包括初始化数据时调用权限申请的最佳实践,以及如何处理权限请求后的回调。

动态申请权限


用于安卓6.0以上

位置

动态权限的申请基本在初始化页面数据的时调用
数据的初始化应避免写在oncreate(),而是写在onResume(),因为每次回到该页面,都会执行这个onResume()方法。可以实时地更新数据

//@Override
protected void onResume() {
    super.onResume();
    initData();
}

将一些需要用到的常量写成属性。

private String[] contactPermissions = new String[]{
        Manifest.permission.READ_CONTACTS,
        Manifest.permission.WRITE_CONTACTS
};
private static final int CONTACT_REQUEST_CODE =100;

在initData()方法中先进行动态申请

private void initData() {
    int readContacts = ContextCompat.checkSelfPermission(this, Manifest.permission.READ_CONTACTS);
    int writeContacts = ContextCompat.checkSelfPermission(this,Manifest.permission.WRITE_CONTACTS);
    if (readContacts == PackageManager.PERMISSION_GRANTED && writeContacts ==
    PackageManager.PERMISSION_GRANTED){
        //开始获取数据
        getData();
    }else {
        ActivityCompat.requestPermissions(this,contactPermissions,CONTACT_REQUEST_CODE);
    }
}

private void getData() {
}

最后执行回调方法

/**
 * 用户回复后,都会回调这个函数
 * @param requestCode
 * @param permissions
 * @param grantResults 授权的结果保存在此
 */
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    switch (requestCode){
        case CONTACT_REQUEST_CODE:
            int length = contactPermissions.length;
            boolean flag = true;
            for (int i=0; i< length;i ++){
                //PERMISSION_DENIED为被拒绝的权限集
                if (grantResults[i] ==PackageManager.PERMISSION_DENIED){
                    flag = false;
                    break;
                }
                if (flag){
                    getData();
                }
            }
    }
}
Android 系统中,跳转权限申请页面后判断用户是否同意授予权限,`onActivityResult` 方法本身并不直接用于权限申请结果的判断,权限申请结果通常在 `onRequestPermissionsResult` 方法中处理。不过,如果是通过跳转系统设置页面让用户手动开启权限,在跳转设置页面返回后,可通过再次检查权限来判断用户是否开启了权限。 以下是示例代码: ```java import android.Manifest; import android.content.Intent; import android.content.pm.PackageManager; import android.net.Uri; import android.os.Build; import android.os.Bundle; import android.provider.Settings; import android.widget.Toast; import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import androidx.core.app.ActivityCompat; import androidx.core.content.ContextCompat; public class MainActivity extends AppCompatActivity { private static final int PERMISSION_REQUEST_CODE = 1; private static final int SETTINGS_REQUEST_CODE = 2; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 检查权限 if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { // 请求权 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, PERMISSION_REQUEST_CODE); } } @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (requestCode == PERMISSION_REQUEST_CODE) { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { // 权限已授予 Toast.makeText(this, "权限已授予", Toast.LENGTH_SHORT).show(); } else { // 权限被拒绝,引导用户去设置页面手动开启 if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.READ_EXTERNAL_STORAGE)) { // 用户拒绝但未勾选“不再询问”,可再次请求权 ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, PERMISSION_REQUEST_CODE); } else { // 用户拒绝并勾选“不再询问”,跳转到设置页面 Intent intent = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS); Uri uri = Uri.fromParts("package", getPackageName(), null); intent.setData(uri); startActivityForResult(intent, SETTINGS_REQUEST_CODE); } } } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == SETTINGS_REQUEST_CODE) { // 从设置页面返回,再次检查权限 if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED) { Toast.makeText(this, "权限已在设置中开启", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(this, "权限仍未开启", Toast.LENGTH_SHORT).show(); } } } } ``` 在上述代码中,`onRequestPermissionsResult` 方法用于处理权限请求的结果。当权限被拒绝且用户勾选了“不再询问”时,会跳转到应用的设置页面。`onActivityResult` 方法用于处理从设置页面返回后的逻辑,通过再次检查权限来判断用户是否在设置中开启了权限
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值