解析Android聲明和使用權(quán)限
Android定義了一種權(quán)限方案來保護設(shè)備上的資源和功能。例如,在默認情況下,應(yīng)用程序無法訪問聯(lián)系人列表、撥打電話等。下面就以撥打電話為例介紹一下系統(tǒng)對權(quán)限的要求。一般在我們的應(yīng)用中,如果要用到撥打電話的功能,我們會這樣編碼:
Uri uri = Uri.parse("tel:12345678"); Intent intent = new Intent(Intent.ACTION_CALL, uri); startActivity(intent);
默認情況下,我們無權(quán)訪問撥打電話的Activity,控制臺將會報以下異常信息:
ERROR/AndroidRuntime: java.lang.SecurityException: Permission Denial: starting Intent { act=android.intent.action.CALL dat=tel:12345678 cmp=com.android.phone/.OutgoingCallBroadcaster } ...... requires android.permission.CALL_PHONE
看來,我們是缺少了CALL_PHONE這個權(quán)限,這個權(quán)限是Android系統(tǒng)自帶的phone應(yīng)用里定義的權(quán)限:
...... <uses-permission android:name="android.permission.CALL_PHONE" /> ...... <activity android:name="OutgoingCallBroadcaster" android:permission="android.permission.CALL_PHONE" android:theme="@android:style/Theme.NoDisplay" android:configChanges="orientation|keyboardHidden"> <!-- CALL action intent filters, for the various ways of initiating an outgoing call. --> <intent-filter> <action android:name="android.intent.action.CALL" /> <category android:name="android.intent.category.DEFAULT" /> <data android:scheme="tel" /> </intent-filter> <intent-filter> <action android:name="android.intent.action.CALL" /> <category android:name="android.intent.category.DEFAULT" /> <data android:scheme="voicemail" /> </intent-filter> <intent-filter> <action android:name="android.intent.action.CALL" /> <category android:name="android.intent.category.DEFAULT" /> <data android:mimeType="vnd.android.cursor.item/phone" /> <data android:mimeType="vnd.android.cursor.item/phone_v2" /> <data android:mimeType="vnd.android.cursor.item/person" /> </intent-filter> </activity> ......
想要使用此功能,必須在我們的AndroidManifest.xml文件中聲明使用此權(quán)限:
<application ...> ... </application> <uses-permission android:name="android.permission.CALL_PHONE"/>
這告訴系統(tǒng),我們的應(yīng)用使用了此權(quán)限,我們有權(quán)訪問撥打電話的Activity。
我們不僅要問,為什么系統(tǒng)會這樣設(shè)計呢?答案是為了保護用戶資源的安全。要想使用此功能,必須在應(yīng)用中聲明權(quán)限信息,這樣一來,在用戶安裝此應(yīng)用時系統(tǒng)會從應(yīng)用中提取出權(quán)限信息,告訴用戶該應(yīng)用使用到了哪些功能,由用戶判斷該應(yīng)用是否損害自己的安全。
接下來由我來演示一下權(quán)限的定義和使用,我們建立一個phone項目,項目結(jié)構(gòu)如下:
我們設(shè)計的流程是在MainActivity中點擊按鈕,然后跳轉(zhuǎn)到PhoneActivity中,我們會為PhoneActiivty定義相應(yīng)的權(quán)限。
我們先看一下MainActivity和PhoneActivity的代碼:
MainActivity.Java如下:
package com.scott.phone; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.widget.Button; public class MainActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); Button btn = (Button) findViewById(R.id.btn); btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { startActivity(new Intent(MainActivity.this, PhoneActivity.class)); } }); } }
PhoneActivity.java如下:
package com.scott.phone; import android.app.Activity; import android.os.Bundle; import android.widget.TextView; public class PhoneActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); TextView tv = new TextView(this); tv.setText("Yes! It works."); setContentView(tv); } }
最重要的是AndroidManifest.xml文件,我們所有的權(quán)限聲明配置都在此文件中完成:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.scott.phone" android:versionCode="1" android:versionName="1.0"> <!-- 聲明一個權(quán)限 --> <permission android:protectionLevel="normal" android:name="scott.permission.MY_CALL_PHONE"/> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".MainActivity" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <!-- 為Activity應(yīng)用已定義的權(quán)限 --> <activity android:name=".PhoneActivity" android:permission="scott.permission.MY_CALL_PHONE"> <intent-filter> <!-- 注意這個action 在其他應(yīng)用中可使用此action訪問此Activity --> <action android:name="scott.intent.action.MY_CALL"/> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity> </application> <!-- 在同一應(yīng)用中訪問PhoneActivity也需要加上權(quán)限 --> <uses-permission android:name="scott.permission.MY_CALL_PHONE"/> <uses-sdk android:minSdkVersion="8" /> </manifest>
需要注意的是,在聲明權(quán)限時需要一個android:protectionLevel的屬性,它代表“風險級別”。必須是以下值之一:
normal、dangerous、signature、signatureOrSystem。
- normal表示權(quán)限是低風險的,不會對系統(tǒng)、用戶或其他應(yīng)用程序造成危害。
- dangerous表示權(quán)限是高風險的,系統(tǒng)將可能要求用戶輸入相關(guān)信息,才會授予此權(quán)限。
- signature告訴Android,只有當應(yīng)用程序所用數(shù)字簽名與聲明此權(quán)限的應(yīng)用程序所有數(shù)字簽名相同時,才能將權(quán)限授給它。
- signatureOrSystem告訴Android,將權(quán)限授給具有相同數(shù)字簽名的應(yīng)用程序或Android包類,這一級別適用于非常特殊的情況,比如多個供應(yīng)商需要通過系統(tǒng)影像共享功能時。
另外一個是android:permissionGroup屬性,表示一個權(quán)限組??梢詫?quán)限放在一個組中,但對于自定義權(quán)限,應(yīng)該避免設(shè)置此屬性。如果確實希望設(shè)置此屬性,可以使用以下屬性代替:android.permission-group.SYSTEM_TOOLS。
下面是兩個活動的截圖:
以上過程都是在一個內(nèi)部完成的,現(xiàn)在假如我們的這個phone應(yīng)用作為系統(tǒng)內(nèi)置的應(yīng)用,做為開發(fā)者,我們新建一個app,然后訪問phone應(yīng)用里的PhoneActivity。app的結(jié)構(gòu)圖如下:
我們在MainActivity里放置一個按鈕,點擊之后跳轉(zhuǎn)到phone應(yīng)用的PhoneActivity中。MainActivity.java代碼如下:
package com.scott.app; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.widget.Button; public class MainActivity extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); Button btn = (Button) findViewById(R.id.btn); btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent("scott.intent.action.MY_CALL"); startActivity(intent); } }); } }
然后我們需要在AndroidManifest.xml文件中配置相應(yīng)的權(quán)限:
<application ...> ... </application> <uses-permission android:name="scott.permission.MY_CALL_PHONE"/>
點擊按鈕,就可以順利地跳轉(zhuǎn)到PhoneActivity了。截圖如下:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
刷新Activity中的scrollview示例(局部ui刷新)
代碼很簡單,但是很實用,適合在一個Activity中要刷新局部的UI,比如在掃描一維碼的時候,要把每次掃描的結(jié)果都顯示在界面上2014-01-01Android 8.0升級不跳轉(zhuǎn)應(yīng)用安裝頁面的解決方法
這篇文章主要為大家詳細介紹了Android 8.0升級不跳轉(zhuǎn)應(yīng)用安裝頁面的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06Android文本框搜索和清空效果實現(xiàn)代碼及簡要概述
在工作過程中可能會遇到這樣一個效果:文本框輸入為空時顯示輸入的圖標;不為空時顯示清空的圖標,此時點擊清空圖標能清空文本框內(nèi)輸入文字,感興趣的你可以了解下哦,或許對你學(xué)習(xí)android有所幫助2013-02-02淺談Android中適配器的notifyDataSetChanged()為何有時不刷新
這篇文章主要介紹了淺談Android中適配器的notifyDataSetChanged()為何有時不刷新,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07Android關(guān)于Glide的使用(高斯模糊、加載監(jiān)聽、圓角圖片)
這篇文章主要為大家詳細介紹了Android關(guān)于Glide的使用,內(nèi)容豐富,高斯模糊、加載監(jiān)聽、圓角圖片希望大家可以掌握,感興趣的小伙伴們可以參考一下2016-11-11Android12四大組件之Activity生命周期變化詳解
雖然說我們天天都在使用Activity,但是你真的對Activity的生命機制完全了解了嗎?Activity的生命周期方法只有七個,但是其實那只是默認的情況。也就是說在其他情況下,Activity的生命周期可能不會是按照我們以前所知道的流程,本章著重講解Activity的生命周期變化2022-07-07