Android中的權(quán)限問(wèn)題
在Android程序中,在執(zhí)行形如訪問(wèn)網(wǎng)絡(luò)、讀取聯(lián)系人時(shí)都要聲明權(quán)限,在 Android 系統(tǒng)版本小于6.0時(shí),所有的權(quán)限只需要在AndroidManifest文件中聲明就可以使用對(duì)應(yīng)的功能了。 但是在Android6.0版本以上,Android將權(quán)限分為了普通權(quán)限和危險(xiǎn)權(quán)限,其中普通權(quán)限的使用和以前的Android版本一樣,直接在AndroidManifest文件中聲明就行了,系統(tǒng)會(huì)自動(dòng)幫我們授權(quán),但是危險(xiǎn)權(quán)限不僅要在AndroidManifest文件中聲明,還需要在使用權(quán)限的時(shí)候通過(guò)代碼來(lái)判斷用戶授權(quán)并且對(duì)用戶授權(quán)的結(jié)果進(jìn)行對(duì)應(yīng)的處理。那么哪些權(quán)限是危險(xiǎn)權(quán)限呢,下面給出了Android所有的危險(xiǎn)權(quán)限,那么除了下表中的危險(xiǎn)權(quán)限,其它的權(quán)限就都是Android普通權(quán)限了:
我們可以通過(guò)權(quán)限組的方式大致記一下危險(xiǎn)權(quán)限:
- 讀寫日歷:android.permission.READ_CALENDAR android.permission.WRITE_CALENDAR
- 使用相機(jī): android.permission.CAMERA
- 讀寫聯(lián)系人:android.permission.READ_CONTACTS android.permission.WRITE_CONTACTS
- android.permission.GET_ACCOUNTS
- 位置服務(wù):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
- 讀寫手機(jī)儲(chǔ)存:android.permission.READ_EXTERNAL_STORAGE android.permission.WRITE_EXTERNAL_STORAGE
好了,以上就是Android的所有危險(xiǎn)權(quán)限,我們?cè)谑褂眠@些權(quán)限的時(shí)候不僅要在AndroidManifest文件中聲明,還需要在代碼中對(duì)用戶的授權(quán)情況進(jìn)行處理,下面以一個(gè)簡(jiǎn)單的例子來(lái)看一下如何在代碼中處理危險(xiǎn)權(quán)限:
新建一個(gè)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="輸入你想撥打的電話號(hào)碼" />
- <Button
- android:id="@+id/callPhoneButton"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="撥打"/>
- </LinearLayout>
很簡(jiǎn)單的布局文件,一行EditText控件用于,電話號(hào)碼,一行Button用于撥打電話::
接下來(lái)是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) {
- /*
- * 先判斷用戶以前有沒(méi)有對(duì)我們的應(yīng)用程序允許過(guò)打電話的權(quán)限,
- * 如果有,那么直接打電話,如果沒(méi)有,那么向用戶申請(qǐng),并且回調(diào)onRequestPermissionResult方法
- */
- if(ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE)
- != PackageManager.PERMISSION_GRANTED) {
- /*
- * 下面是對(duì)權(quán)限進(jìn)行申請(qǐng),第二個(gè)參數(shù)填入權(quán)限名,如果有多個(gè)權(quán)限,那么第二個(gè)參數(shù)String數(shù)組加入多個(gè)權(quán)限參數(shù)
- */
- 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();
- }
- }
- /*
- * 當(dāng)我們向用戶申請(qǐng)權(quán)限的時(shí)候,用戶操作的結(jié)果會(huì)調(diào)用這個(gè)方法,無(wú)論用戶允許或者禁止,
- * 我們要在這個(gè)方法里面做出對(duì)應(yīng)的處理
- */
- @Override
- public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
- super.onRequestPermissionsResult(requestCode, permissions, grantResults);
- switch (requestCode) {
- /*
- * 對(duì)傳入的requestCode進(jìn)行判斷
- */
- case PERMISSION_REQUEST_CODE:
- // 如果用戶授權(quán)
- if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
- callPhonenumber();
- } else {
- Toast.makeText(this, "打電話權(quán)限已被用戶拒絕", Toast.LENGTH_SHORT).show();
- }
- }
- }
- }
在MainActivity.java中我們對(duì)我們需要的權(quán)限進(jìn)行了處理,
最后別忘了在AndroidManifest文件中聲明打電話權(quán)限:
- <uses-permission android:name="android.permission.CALL_PHONE" />
下面來(lái)運(yùn)行一下:
我們輸入一個(gè)號(hào)碼,點(diǎn)擊“撥打”按鈕:
因?yàn)槲覀兪堑谝淮芜\(yùn)行這個(gè)程序,所以用戶以前并沒(méi)有對(duì)我們的程序進(jìn)行授權(quán),因此出現(xiàn)權(quán)限申請(qǐng)對(duì)話框,我們點(diǎn)擊DENY(否):
成功彈出了提示框,那么我們?cè)僭囈淮吸c(diǎn)擊ALLOW(允許)試試:
成功的進(jìn)入撥打電話的界面并且撥打我們輸入的電話號(hào)碼!
當(dāng)我們?cè)试S了之后,那么程序以后就不需要再經(jīng)過(guò)用戶授權(quán)了,即可以直接撥打電話(除非用戶在應(yīng)用程序管理中收回了我們的打電話的權(quán)限)。