亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解Android中的權限問題

發布時間:2021-11-26 15:50:58 來源:億速云 閱讀:197 作者:柒染 欄目:移動開發

今天就跟大家聊聊有關如何理解Android中的權限問題,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

在Android程序中,在執行形如訪問網絡、讀取聯系人時都要聲明權限,在 Android  系統版本小于6.0時,所有的權限只需要在AndroidManifest文件中聲明就可以使用對應的功能了。  但是在Android6.0版本以上,Android將權限分為了普通權限和危險權限,其中普通權限的使用和以前的Android版本一樣,直接在AndroidManifest文件中聲明就行了,系統會自動幫我們授權,但是危險權限不僅要在AndroidManifest文件中聲明,還需要在使用權限的時候通過代碼來判斷用戶授權并且對用戶授權的結果進行對應的處理。那么哪些權限是危險權限呢,下面給出了Android所有的危險權限,那么除了下表中的危險權限,其它的權限就都是Android普通權限了:

我們可以通過權限組的方式大致記一下危險權限:

  1. 讀寫日歷:android.permission.READ_CALENDAR android.permission.WRITE_CALENDAR

  2. 使用相機: android.permission.CAMERA

  3. 讀寫聯系人:android.permission.READ_CONTACTS  android.permission.WRITE_CONTACTS

  • android.permission.GET_ACCOUNTS

  1. 位置服務:android.permission.ACCESS_FINE_LOCATION ACCESS_COARSE_LOCATION

  2. 電話: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

  3. 使用傳感器:android.permission.BODY_SENSORS

  4. 短信:android.permission.SEND_SMS android.permission.RECEIVE_SMS  android.permission.READ_SMS android.permission.RECEIVE_WAP_PUSH RECEIVE_MMS

  5. 讀寫手機儲存: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" />

下面來運行一下:

如何理解Android中的權限問題

我們輸入一個號碼,點擊“撥打”按鈕:

如何理解Android中的權限問題

因為我們是第一次運行這個程序,所以用戶以前并沒有對我們的程序進行授權,因此出現權限申請對話框,我們點擊DENY(否):

如何理解Android中的權限問題

成功彈出了提示框,那么我們再試一次點擊ALLOW(允許)試試:

如何理解Android中的權限問題

成功的進入撥打電話的界面并且撥打我們輸入的電話號碼!

當我們允許了之后,那么程序以后就不需要再經過用戶授權了,即可以直接撥打電話(除非用戶在應用程序管理中收回了我們的打電話的權限)。

看完上述內容,你們對如何理解Android中的權限問題有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

资阳市| 那曲县| 高淳县| 金寨县| 牡丹江市| 云林县| 汉源县| 林州市| 泰来县| 延津县| 德钦县| 玛多县| 望江县| 宜黄县| 永福县| 施秉县| 小金县| 汕尾市| 兴义市| 年辖:市辖区| 墨竹工卡县| 白山市| 会泽县| 大埔区| 宣恩县| 瑞昌市| 东宁县| 普陀区| 合作市| 东明县| 讷河市| 岚皋县| 湘潭市| 灵武市| 龙海市| 庆阳市| 义乌市| 称多县| 永吉县| 赫章县| 承德县|