运行时权限 案例——实现按键获取电话权限并拨打电话

运行时权限

ContentProvider会使用到运行时权限的功能
运行时权限是安卓6.0添加的功能 用于避免app厂商强迫用户开启其所要的权限 (不给权限就不让安装)比如说一款相机软件在运行时申请地理位置权限 就算我拒绝给这个权限 我仍然可以使用这个app的其他功能 而不是像之前一样不能安装
并不是所有权限都需要在运行时申请 否则不停的授权也很麻烦 android将权限归成了两类 一类是普通权限 一类是危险权限 普通权限指哪些不会直接威胁到用户的安全和隐私的权限 系统会自动授权不需要用户手动操作 危险权限表示那些可能会触及用户隐私 或者对设备安全性造成影响的权限 必须要用户点击授权才行

安卓所有的危险权限 一共9组24个
在这里插入图片描述

运行时申请权限

比如CALL_PHONE
AndroidManifest.xml文件中添加权限

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.supertextview">

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

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/Theme.SuperTextView">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

在xml设置一个button


public class MainActivity extends AppCompatActivity {
    private Button btn;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn = findViewById(R.id.btn);
        btn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (ContextCompat.checkSelfPermission(MainActivity.this,
                        Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {
                    ActivityCompat.requestPermissions(MainActivity.this,
                            new String[]{Manifest.permission.CALL_PHONE}, 1);
                } else {
                    call();
                }
            }
        });
    }

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

    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
        switch (requestCode) {
            case 1:
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    call();
                } else {
                    Toast.makeText(this,"需要权限", Toast.LENGTH_SHORT).show();
                }
                break;
            default:
        }
    }
}

在这里插入图片描述

Android 12.0 默认授予权限是指在新版本的Android操作系统中,应用程序在安装后默认被授予一些常用权限,无需用户的明确操作即可使用相关功能。 随着技术的进步和用户对隐私保护的需求增加,Android 12.0引入了一项新的特性,即默认授予权限。在以往的版本中,当用户安装应用程序后,通常需要手动为应用程序授予权限才能正常使用。而在Android 12.0中,默认授予权限可以让应用程序在安装后即可使用与其功能相关的一些权限,无需用户干预。 这样的设计有其一定的优势和便利性。首先,对于一些常见的权限,如相机、位置信息等,大多数用户会默认同意,因为这些权限是应用程序正常运行所必需的。通过默认授予权限,可以简化用户使用新应用程序的流程,减少繁琐的权限请求步骤。其次,在某些特殊情况下,用户可能会忽略某些权限请求,导致应用程序无法正常运行。默认授予权限可以避免因用户的不当操作而引发的一些问题。 然而,虽然默认授予权限在某些情况下提供了方便,但也需要注意潜在的隐私安全问题。默认授予权限可能会导致应用程序在未经用户许可的情况下获取到用户的敏感信息,因此需要在系统层面和开发者层面上加强对权限的控制和监管。 总之,Android 12.0默认授予权限是一项旨在提供便利和简化用户体验的新特性,但也需要在确保用户隐私和安全的前提下加以注意和保护。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值