Android 6.0 动态申请权限

本文介绍了Android 6.0系统中针对targetSdk Version大于23的应用,如何进行动态权限申请。文章通过permission.CALL_PHONE权限为例,详细阐述了在AndroidManifest.xml中注册权限以及在Java代码中实现动态申请的步骤,重点关注了危险权限的用户授权需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  Android 6.0 系统默认为targetSdk Version 小于 23 的应用授予了所申请的所有权限,如果你的 app 设置的 targetSdk Version 小于 23,在运行时不会因为权限的问题而崩溃,当 targetSdk Version 大于 23 时,app 不得不在运行时来询问用户授予权限,当然了,也不是所有权限都需要询问,Google 把权限分为两类,一类是普通权限(Normal Permission),这类权限一般不会涉及到用户的隐私,另一类是危险权限(Dangerous Permission),这类权限会涉及到用户隐私,需要用户授权。

 

动态申请权限:

  这里我用 permission.CALL_PHONE 这个权限来做演示:

  (1) 在 AndroidManifest.xml 里面注册拨打电话的权限:

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

  (2) Java 代码如下:

import android.Manifest;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.net.Uri;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;


public class MainActivity extends AppCompatActivity {

    private Button button;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button = findViewById(R.id.btn_call);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                call();
            }
        });
    }

    private void call() {
        //检查是否有拨打电话的权限
        if (ActivityCompat.checkSelfPermission(this, Manifest.permission.CALL_PHONE)
                != PackageManager.PERMISSION_GRANTED) {
            //申请权限
            ActivityCompat.requestPermissions(this,
                    new String[]{Manifest.permission.CALL_PHONE},
                    1);
        } else {
            callPhone();
        }
    }

    private void callPhone() {
        Intent intent = new Intent(Intent.ACTION_CALL);
        Uri uri = Uri.parse("tel:" + "10086");
        intent.setData(uri);
        try{
            startActivity(intent);
        } catch (SecurityException e) {
            e.printStackTrace();
        }
    }

    //申请权限回调
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
                                           @NonNull int[] grantResults) {
        if (requestCode == 1) {
            if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                callPhone();
            } else {
                Toast.makeText(this, "权限被拒绝", Toast.LENGTH_LONG).show();
            }
        }
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值