Android 6.0运行时权限 (危险权限)

转载自:https://blog.csdn.net/qq_34763699/article/details/80509882

一、说明

Android 6.0开始,Google将权限分为两类,一类是 Normal Permission, 这类权限一般不涉及用户隐私,是不需要用户进行授权的,比如手机震动、访问网络等;另一类是 Dangerous Permission,一般是涉及到用户隐私的,需要用户进行授权,比如读取sdcard、访问通讯录等。

二、危险权限列表

下表列出了Android所有的危险权限,剩余的权限就都是普通权限
需注意表中每个危险权限都属于一个权限组,我们在运行时权限处理时使用权限名,用户一旦同意授权了,那么该权限组中其他权限也将同时被授权

三、在程序运行时申请权限

以拨打电话为例

界面很简单,就一个按钮,点击后拨打10086.
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="demo.ljn.com.demo_20180531.MainActivity">

    <Button
        android:id="@+id/Make_Call"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Make_Call" />

</android.support.constraint.ConstraintLayout>

public class MainActivity extends AppCompatActivity {

    private Button makeCall;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        makeCall = findViewById(R.id.Make_Call);
        makeCall.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                //判断用户是否已经给程序授权, 第一个参数 context 第二个参数 具体权限名
                if(ContextCompat.checkSelfPermission(MainActivity.this,
                        Manifest.permission.CALL_PHONE)!= PackageManager.PERMISSION_GRANTED){

                    //未授权,调用 ActivityCompat.requestPermissions()方法 想用户申请授权
                    //参数 1 Activity实例 2 申请的权限名数组 3 请求码 只要是唯一即可
                    ActivityCompat.requestPermissions(MainActivity.this,
                            new String[]{Manifest.permission.CALL_PHONE},1);

                }else{
                    call();
                }
            }
        });
    }

    /**
     * 拨打电话
     */
    private void call() {
        Intent intent = new Intent();
        intent.setData(Uri.parse("tel:10086"));
        startActivity(intent);
    }

    /**
     * 申请授权结果
     * @param requestCode 请求码对应  ActivityCompat.requestPermissions(MainActivity.this,
    new String[]{Manifest.permission.CALL_PHONE},1);中的请求码  1
     * @param permissions 权限列表
     * @param grantResults 请求结果
     */

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

            case 1:
                if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    //用户同意 拨打电话
                    call();

                }else{
                    //用户不同意权限 提示用户
                    Toast.makeText(this, "你没有申请权限", Toast.LENGTH_SHORT).show();
                }
                break;



        }
    }
}

当然,配置文件AndroidManifest.xml 中,也要加上权限
<uses-permission android:name="android.permission.CALL_PHONE"/>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值