1. <td id="llmub"><ruby id="llmub"></ruby></td>

    2. |
      |
      51CTO旗下網站
      |
      |
      移動端

      Android中的權限問題

      在Android程序中,在執行形如訪問網絡、讀取聯系人時都要聲明權限,在 Android 系統版本小于6.0時,所有的權限只需要在AndroidManifest文件中聲明就可以使用對應的功能了。

      作者:Growup來源:安卓巴士|2019-10-16 16:31

      在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:

      1. <?xml version="1.0" encoding="utf-8"?> 
      2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
      3.  xmlns:tools="http://schemas.android.com/tools" 
      4.  android:id="@+id/activity_main" 
      5.  android:layout_width="match_parent" 
      6.  android:layout_height="match_parent" 
      7.  android:orientation="vertical" 
      8.  android:gravity="center_horizontal" 
      9.  tools:context="com.example.administrator.blogandroidpermissiondeal.MainActivity"
      10.  <EditText 
      11.  android:id="@+id/phonenumberEditText" 
      12.  android:layout_width="wrap_content" 
      13.  android:layout_height="wrap_content" 
      14.  android:hint="輸入你想撥打的電話號碼" /> 
      15.  <Button 
      16.  android:id="@+id/callPhoneButton" 
      17.  android:layout_width="wrap_content" 
      18.  android:layout_height="wrap_content" 
      19.  android:text="撥打"/> 
      20. </LinearLayout> 

      很簡單的布局文件,一行EditText控件用于,電話號碼,一行Button用于撥打電話::

      接下來是MainActivity.java:

      1. package com.example.administrator.blogandroidpermissiondeal; 
      2. import android.Manifest; 
      3. import android.content.Intent; 
      4. import android.content.pm.PackageManager; 
      5. import android.net.Uri; 
      6. import android.support.annotation.NonNull; 
      7. import android.support.v4.app.ActivityCompat; 
      8. import android.support.v4.content.ContextCompat; 
      9. import android.support.v7.app.AppCompatActivity; 
      10. import android.os.Bundle; 
      11. import android.view.View
      12. import android.widget.Button; 
      13. import android.widget.EditText; 
      14. import android.widget.Toast; 
      15. public class MainActivity extends AppCompatActivity { 
      16.  private Button button = null
      17.  private EditText editText = null
      18.  private static final int PERMISSION_REQUEST_CODE = 1; 
      19.  @Override 
      20.  protected void onCreate(Bundle savedInstanceState) { 
      21.  super.onCreate(savedInstanceState); 
      22.  setContentView(R.layout.activity_main); 
      23.  editText = (EditText) findViewById(R.id.phonenumberEditText); 
      24.  button = (Button) findViewById(R.id.callPhoneButton); 
      25.  button.setOnClickListener(new View.OnClickListener() { 
      26.  @Override 
      27.  public void onClick(View v) { 
      28.  /* 
      29.  * 先判斷用戶以前有沒有對我們的應用程序允許過打電話的權限, 
      30.  * 如果有,那么直接打電話,如果沒有,那么向用戶申請,并且回調onRequestPermissionResult方法 
      31.  */ 
      32.  if(ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE) 
      33.  != PackageManager.PERMISSION_GRANTED) { 
      34.  /* 
      35.  * 下面是對權限進行申請,第二個參數填入權限名,如果有多個權限,那么第二個參數String數組加入多個權限參數 
      36.  */ 
      37.  ActivityCompat.requestPermissions(MainActivity.this, 
      38.  new String[]{Manifest.permission.CALL_PHONE}, PERMISSION_REQUEST_CODE); 
      39.  } else { 
      40.  callPhonenumber(); 
      41.  } 
      42.  } 
      43.  }); 
      44.  } 
      45.  private void callPhonenumber() { 
      46.  try { 
      47.  Intent intent = new Intent(Intent.ACTION_CALL); 
      48.  intent.setData(Uri.parse("tel:" + editText.getText().toString())); 
      49.  startActivity(intent); 
      50.  }catch (Exception e) { 
      51.  e.printStackTrace(); 
      52.  } 
      53.  } 
      54.  /* 
      55.  * 當我們向用戶申請權限的時候,用戶操作的結果會調用這個方法,無論用戶允許或者禁止, 
      56.  * 我們要在這個方法里面做出對應的處理 
      57.  */ 
      58.  @Override 
      59.  public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { 
      60.  super.onRequestPermissionsResult(requestCode, permissions, grantResults); 
      61.  switch (requestCode) { 
      62.  /* 
      63.  * 對傳入的requestCode進行判斷 
      64.  */ 
      65.  case PERMISSION_REQUEST_CODE: 
      66.  // 如果用戶授權 
      67.  if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { 
      68.  callPhonenumber(); 
      69.  } else { 
      70.  Toast.makeText(this, "打電話權限已被用戶拒絕", Toast.LENGTH_SHORT).show(); 
      71.  } 
      72.  } 
      73.  } 

      在MainActivity.java中我們對我們需要的權限進行了處理,

      最后別忘了在AndroidManifest文件中聲明打電話權限:

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

      下面來運行一下:

      Android中的權限問題

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

      Android中的權限問題

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

      Android中的權限問題

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

      Android中的權限問題

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

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

      【編輯推薦】

      1. 微軟為什么要推出一款 Android 手機?
      2. 2019年10月Android安全補丁發布:共計修復26處漏洞
      3. 谷歌官方首次提及Android 11
      4. 類比于微信,如何對Apk進行極限壓縮,談下Android壓縮8大步
      5. Google又出新規!沒這些功能Android系統禁止使用
      【責任編輯:未麗燕 TEL:(010)68476606】

      點贊 0
      分享:
      大家都在看
      猜你喜歡

      訂閱專欄+更多

      CentOS 8 全新學習術

      CentOS 8 全新學習術

      CentOS 8 正式發布
      共16章 | UbuntuServer

      229人訂閱學習

      用Python玩轉excel

      用Python玩轉excel

      讓重復操作傻瓜化
      共3章 | DE8UG

      216人訂閱學習

      AI入門級算法

      AI入門級算法

      算法常識
      共22章 | 周蘿卜123

      182人訂閱學習

      讀 書 +更多

      精通JavaScript動態網頁編程(實例版)

      本書通過大量實例代碼,以ECMA-262版本3為基礎,結合JavaScript 1.5和JavaScript 5.5,由淺入深、循序漸進地介紹了JavaScript知識要點與編...

      訂閱51CTO郵刊

      點擊這里查看樣刊

      訂閱51CTO郵刊

      51CTO服務號

      51CTO官微

      日韩大片,babesxxx,亚洲在线电影,性直播视频