在Android程序中,在执行形如访问网络、读取联系人时都要声明权限,在 Android 系统版本小于6.0时,所有的权限只需要在AndroidManifest文件中声明就可以使用对应的功能了。 但是在Android6.0版本以上,Android将权限分为了普通权限和危险权限,其中普通权限的使用和以前的Android版本一样,直接在AndroidManifest文件中声明就行了,系统会自动帮我们授权,但是危险权限不仅要在AndroidManifest文件中声明,还需要在使用权限的时候通过代码来判断用户授权并且对用户授权的结果进行对应的处理。那么哪些权限是危险权限呢,下面给出了Android所有的危险权限,那么除了下表中的危险权限,其它的权限就都是Android普通权限了:
我们可以通过权限组的方式大致记一下危险权限:
- 读写日历:android.permission.READ_CALENDAR android.permission.WRITE_CALENDAR
- 使用相机: android.permission.CAMERA
- 读写联系人:android.permission.READ_CONTACTS android.permission.WRITE_CONTACTS
- android.permission.GET_ACCOUNTS
- 位置服务:android.permission.ACCESS_FINE_LOCATION ACCESS_COARSE_LOCATION
- 电话:android.permission.READ_PHONE_STATE android.permission.CALL_PHONE android.permission.READ_CALL_LOG android.permission.WRITE_CALL_LOG android.permission.ADD_VOICEMAIL android.permission.USE_SIP android.permission.PROGRESS_OUTGOING_CALLS
- 使用传感器:android.permission.BODY_SENSORS
- 短信:android.permission.SEND_SMS android.permission.RECEIVE_SMS android.permission.READ_SMS android.permission.RECEIVE_WAP_PUSH RECEIVE_MMS
- 读写手机储存:android.permission.READ_EXTERNAL_STORAGE android.permission.WRITE_EXTERNAL_STORAGE
好了,以上就是Android的所有危险权限,我们在使用这些权限的时候不仅要在AndroidManifest文件中声明,还需要在代码中对用户的授权情况进行处理,下面以一个简单的例子来看一下如何在代码中处理危险权限:
新建一个Android工程:
activity_main.xml:
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- xmlns:tools="http://schemas.android.com/tools"
- android:id="@+id/activity_main"
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:orientation="vertical"
- android:gravity="center_horizontal"
- tools:context="com.example.administrator.blogandroidpermissiondeal.MainActivity">
- <EditText
- android:id="@+id/phonenumberEditText"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:hint="输入你想拨打的电话号码" />
- <Button
- android:id="@+id/callPhoneButton"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="拨打"/>
- </LinearLayout>
很简单的布局文件,一行EditText控件用于,电话号码,一行Button用于拨打电话::
接下来是MainActivity.java:
- package com.example.administrator.blogandroidpermissiondeal;
- 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.v4.content.ContextCompat;
- import android.support.v7.app.AppCompatActivity;
- import android.os.Bundle;
- import android.view.View;
- import android.widget.Button;
- import android.widget.EditText;
- import android.widget.Toast;
- public class MainActivity extends AppCompatActivity {
- private Button button = null;
- private EditText editText = null;
- private static final int PERMISSION_REQUEST_CODE = 1;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- editText = (EditText) findViewById(R.id.phonenumberEditText);
- button = (Button) findViewById(R.id.callPhoneButton);
- button.setOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View v) {
- /*
- * 先判断用户以前有没有对我们的应用程序允许过打电话的权限,
- * 如果有,那么直接打电话,如果没有,那么向用户申请,并且回调onRequestPermissionResult方法
- */
- if(ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE)
- != PackageManager.PERMISSION_GRANTED) {
- /*
- * 下面是对权限进行申请,第二个参数填入权限名,如果有多个权限,那么第二个参数String数组加入多个权限参数
- */
- ActivityCompat.requestPermissions(MainActivity.this,
- new String[]{Manifest.permission.CALL_PHONE}, PERMISSION_REQUEST_CODE);
- } else {
- callPhonenumber();
- }
- }
- });
- }
- private void callPhonenumber() {
- try {
- Intent intent = new Intent(Intent.ACTION_CALL);
- intent.setData(Uri.parse("tel:" + editText.getText().toString()));
- startActivity(intent);
- }catch (Exception e) {
- e.printStackTrace();
- }
- }
- /*
- * 当我们向用户申请权限的时候,用户操作的结果会调用这个方法,无论用户允许或者禁止,
- * 我们要在这个方法里面做出对应的处理
- */
- @Override
- public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
- super.onRequestPermissionsResult(requestCode, permissions, grantResults);
- switch (requestCode) {
- /*
- * 对传入的requestCode进行判断
- */
- case PERMISSION_REQUEST_CODE:
- // 如果用户授权
- if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
- callPhonenumber();
- } else {
- Toast.makeText(this, "打电话权限已被用户拒绝", Toast.LENGTH_SHORT).show();
- }
- }
- }
- }
在MainActivity.java中我们对我们需要的权限进行了处理,
最后别忘了在AndroidManifest文件中声明打电话权限:
- <uses-permission android:name="android.permission.CALL_PHONE" />
下面来运行一下:
我们输入一个号码,点击“拨打”按钮:
因为我们是第一次运行这个程序,所以用户以前并没有对我们的程序进行授权,因此出现权限申请对话框,我们点击DENY(否):
成功弹出了提示框,那么我们再试一次点击ALLOW(允许)试试:
成功的进入拨打电话的界面并且拨打我们输入的电话号码!
当我们允许了之后,那么程序以后就不需要再经过用户授权了,即可以直接拨打电话(除非用户在应用程序管理中收回了我们的打电话的权限)。