成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Android中的權限問題

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

在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中的權限問題

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

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

責任編輯:未麗燕 來源: 安卓巴士
相關推薦

2011-09-08 09:57:04

Ubunturoot

2010-08-12 13:11:54

Universal AAndroid開發

2013-06-28 14:00:28

Android

2018-04-18 09:18:44

數據庫MySQL存儲過程

2019-01-02 13:03:53

MySQL存儲權限

2011-03-03 15:13:05

ProFTPD權限

2011-01-10 10:45:20

SQL Server數

2023-01-30 08:09:18

權限GreatSQL運行

2010-01-07 16:10:22

Ubuntu root

2010-04-23 16:51:44

Aix ACL

2013-03-26 13:38:12

Android per

2015-11-09 14:17:51

2010-08-09 14:01:22

關系法則

2010-05-20 11:25:14

IIS服務器

2010-06-04 19:31:25

遠程MySQL權限

2009-11-06 14:07:58

Oracle用戶表空間

2010-04-23 17:07:07

Aix權限

2010-04-20 14:06:07

NTFS權限

2010-09-08 15:07:24

SQL Server用戶操作權限

2013-03-25 10:36:20

Android解決問題代碼片段
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91国内精精品久久久久久婷婷 | 黄色毛片黄色毛片 | 一区二区视频在线 | 99riav国产一区二区三区 | 国产精品成人久久久久 | 黄色av网站在线免费观看 | 成人av免费在线观看 | 久久婷婷香蕉热狠狠综合 | 欧美xxxx色视频在线观看免费 | 天堂视频一区 | 一级毛片免费看 | 欧美精品在线观看 | 青青草精品 | 日本不卡视频 | 亚洲精久久 | 一级女毛片 | 欧美综合在线视频 | heyzo在线| 免费毛片在线 | 亚洲成年在线 | 精品欧美一区二区三区久久久 | 久草精品视频 | 欧美亚洲国产一区二区三区 | 国产精品日韩欧美一区二区 | 午夜精品久久久久久久久久久久久 | 国产高清视频 | 国产精品色婷婷久久58 | 免费观看色 | 黄色网络在线观看 | 日韩高清中文字幕 | 欧美精品一区二区三区四区五区 | 黑色丝袜三级在线播放 | 日本不卡高清视频 | av手机在线看 | 亚洲高清av | 综合色在线 | 一色桃子av一区二区 | 久久久久成人精品 | 精品一区二区在线视频 | 狠狠插天天干 | 亚洲精品欧美精品 |