Android运行时动态申请权限完整实例

前言

在Android6.0之前,我们安装App时会列出安装的App的访问权限,并且只有安装时会出现一次。一旦我们同意安装了此App,这个App就可以在用户毫不知情的情况下访问权限内的所有东西。eg:用户的通信信息,用户位置等信息,这会侵犯用户的隐私。在Android6.0以后就不会在出现安装时授予权限,取而代之的是,App必须在运行时询问用户来授予权限。


直接上代码eg:


public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        this.findViewById(R.id.tv_callPhone).setOnClickListener(new View.OnClickListener() {
            @SuppressLint("MissingPermission")
            @Override
            public void onClick(View v) {
                call();
            }


        });
    }

    /**
     * 检查权限
     */
    private void call() {
        /**
         * 检查App是否有permission.CALL_PHONE权限,就申请权限
         */
        if (ActivityCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {
          
            /**
             * 没有permission.CALL_PHONE权限,就申请权限
             */
            ActivityCompat.requestPermissions(MainActivity.this,
                    new String[]{Manifest.permission.CALL_PHONE}, 66);
        } else {
            callPhone();
        }

    }


    /**
     * 拨打电话
     */
    @SuppressLint("MissingPermission")
    private void callPhone() {
        Intent intent = new Intent(Intent.ACTION_CALL);
        Uri uri = Uri.parse("tel:" + 10085);
        intent.setData(uri);
        startActivity(intent);
    }


    /**
     * 申请权限的回调结果
     *
     * @param requestCode  请求码
     * @param permissions  请求权限
     * @param grantResults 授权结果
     */
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);

        if (requestCode == 66) {
            if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                callPhone();
            } else {
                Toast.makeText(this,"权限被拒绝",Toast.LENGTH_LONG).show();
            }
        }
    }
}

当我们点击调用call方法,call方法首先判断APP是否有permission.CALL_PHONE权限,如果有直接调用callPhone方法来拨打电话,否则弹出提示框,如下:



onRequestPermissionsResult就是申请权限的回调,如果点击允许,则调用callPhone方法,否则执行
 
如果我们勾选了该选项,则下一次就不会弹出权限申请提示框,而直接调用 
onRequestPermissionsResult,回调结果为用户最后一次的选择,也就是: 
 
Toast.makeText(this,"权限被拒绝",Toast.LENGTH_LONG).show()。
再次打开该权限:在手机:设置----->应用------->配置应用-------->应用权限----->


处理 不在询问  选项:

如果用户选择了  不在询问  选项,那么每次调用权限都会失败,这给用户带来很不好的体验,所以我们要给用户一个友好的提示
shouldShowRequestPermissionRationale(this, Manifest.permission.CALL_PHONE)方法会返回false,
我们可以做个弹出框给用户一个提示,如下代码:

 if (requestCode == 66) {
        if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
            callPhone();
        } else {
            if (!ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.CALL_PHONE)) {

                AlertDialog alertDialog = new AlertDialog.Builder(this)
                        .setMessage("提示")
                        .setPositiveButton("确定", new DialogInterface.OnClickListener() {
                            @Override
                            public void onClick(DialogInterface dialog, int which) {
                                
                            }
                        })
                        .create();

                alertDialog.show();
            }
            Toast.makeText(this, "权限被拒绝", Toast.LENGTH_LONG).show();
        }
    }
}

到此结束!!!

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的Android GPS定位的完整代码实例,包括权限申请和位置监听器的实现: 1. 首先,在AndroidManifest.xml文件中添加以下权限: ```xml <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> ``` 2. 接着,在MainActivity.java文件中添加以下代码: ```java public class MainActivity extends AppCompatActivity { private LocationManager locationManager; private LocationListener locationListener; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); locationListener = new LocationListener() { @Override public void onLocationChanged(Location location) { // 处理位置变化事件 double latitude = location.getLatitude(); double longitude = location.getLongitude(); Log.i("Location", "Latitude: " + latitude + ", Longitude: " + longitude); } @Override public void onStatusChanged(String provider, int status, Bundle extras) { // 处理位置状态变化事件 } @Override public void onProviderEnabled(String provider) { // 处理位置提供者启用事件 } @Override public void onProviderDisabled(String provider) { // 处理位置提供者禁用事件 } }; if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 1); } else { locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, locationListener); } } @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (requestCode == 1) { if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) { locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, locationListener); } } } } } ``` 以上代码实现了位置监听器(locationListener)的初始化并在权限被授予时开始监听位置变化。你可以根据需要在位置变化事件(onLocationChanged)中实现具体的处理逻辑。 注意:为了让上述代码运行正常,你需要在设备上打开GPS定位功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值