【Android】19.0 許可權處理(一)——執行時許可權處理:撥打電話
1.0 APP在程式內部進行操作,當然是安全的且合理的,但不同應用程式之間如何進行資料訪問?比如向這個例子,需要自己的APP利用到手機上的撥打電話許可權。
2.0 在Android6.0系統之後,Android開發團隊引用了執行時許可權這個功能,終於可以出“店大欺客”這口惡氣,這樣即使我們不賦予APP某項許可權,仍可以安裝並使用該軟體。
這個網站有關於Android系統中完整的許可權列表:
連結: Android API:Manifest.permission許可權清單

2019-02-19_211110.png
(不好意思,瀏覽器已中文翻譯,雖然這翻譯是磕磣了點)
3.0 話不多說,通過一個簡單的小例子,體驗一把到底什麼是Android執行時許可權
新建專案,RuntimePermissionTest,目錄結構如下:

2019-02-19_203507.png
4.0 在activity_main.xml中放一個button按鈕控制元件。
<?xml version="1.0" encoding="utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <Button android:id="@+id/make_call" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="撥打電話" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" app:layout_constraintVertical_bias="0.05" /> </android.support.constraint.ConstraintLayout>
5.0 接著在AndroidManifest.xml中增加一行 <uses-permission android:name="android.permission.CALL_PHONE"/>
:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.runtimepermissiontest"> <uses-permission android:name="android.permission.CALL_PHONE"/> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
6.0 MainActivity.java,說明都在程式碼裡,總之步驟分為三步走。
package com.example.runtimepermissiontest; import android.Manifest; import android.content.Intent; import android.content.pm.PackageManager; import android.net.Uri; 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.Toast; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button makeCall = (Button) findViewById(R.id.make_call); makeCall.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //第一步,判斷使用者是否給應用授權了 //藉助ContextCompat.checkSelfPermission()方法 //該方法接收兩個引數一個是上下文,沒什麼好說的。 //第二個是具體的許可權名 //然後把方法的返回值和PackageManager.PERMISSION_GRANTED作比較,相等說明使用者已經授權 if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) { //第二步,如果不等於,則需要呼叫 ActivityCompat.requestPermissions()方法來向用戶申請許可權 //該方法接收三個引數,第一個要求是Activity的例項 //第二個是一個String陣列,把需要申請的許可權名放入陣列即可 //第三個是請求碼,是唯一值即可,這裡用的“1” ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.CALL_PHONE}, 1); } else { call(); } } }); } private void call() { try { Intent intent = new Intent(Intent.ACTION_CALL); intent.setData(Uri.parse("tel:10010")); startActivity(intent); } catch (SecurityException e) { e.printStackTrace(); } } //第三步,呼叫完requestPermissions()方法後,系統會彈出一個許可權申請的對話方塊 // 無論結果如何,最終都會回撥onRequestPermissionsResult()方法 //授權的結果,會封裝在grantResults中。 // 判斷一下,如果同意了授權就打電話,沒有就涼涼了…… @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { switch (requestCode) { case 1: if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { call(); } else { Toast.makeText(this, "抱歉,沒有該許可權!", Toast.LENGTH_SHORT).show(); } } } }
7.0 跑一下,最後的效果如下:
點選“撥打電話”,提示如下:

2019-02-19_202643.png
選擇,拒絕:

2019-02-19_202705.png
選擇允許:

2019-02-19_202716.png