Android中的權限問題
在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(允許)試試:
成功的進入撥打電話的界面并且撥打我們輸入的電話號碼!
當我們允許了之后,那么程序以后就不需要再經過用戶授權了,即可以直接撥打電話(除非用戶在應用程序管理中收回了我們的打電話的權限)。