
AndroID定义了一种权限方案来保护设备上的资源和功能。例如,在默认情况下,应用程序无法访问联系人列表、拨打电话等。下面就以拨打电话为例介绍一下系统对权限的要求。一般在我们的应用中,如果要用到拨打电话的功能,我们会这样编码:
Uri uri = Uri.parse("tel:12345678"); Intent intent = new Intent(Intent.ACTION_CALL,uri); startActivity(intent); 默认情况下,我们无权访问拨打电话的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这个权限,这个权限是AndroID系统自带的phone应用里定义的权限:
...... <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文件中声明使用此权限:
<application ...> ... </application> <uses-permission androID:name="androID.permission.CALL_PHONE"/>
这告诉系统,我们的应用使用了此权限,我们有权访问拨打电话的Activity。
我们不仅要问,为什么系统会这样设计呢?答案是为了保护用户资源的安全。要想使用此功能,必须在应用中声明权限信息,这样一来,在用户安装此应用时系统会从应用中提取出权限信息,告诉用户该应用使用到了哪些功能,由用户判断该应用是否损害自己的安全。
接下来由我来演示一下权限的定义和使用,我们建立一个phone项目,项目结构如下:
我们设计的流程是在MainActivity中点击按钮,然后跳转到PhoneActivity中,我们会为PhoneActiivty定义相应的权限。
我们先看一下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文件,我们所有的权限声明配置都在此文件中完成:
<?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"> <!-- 声明一个权限 --> <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应用已定义的权限 --> <activity androID:name=".PhoneActivity" androID:permission="scott.permission.MY_CALL_PHONE"> <intent-filter> <!-- 注意这个action 在其他应用中可使用此action访问此Activity --> <action androID:name="scott.intent.action.MY_CALL"/> <category androID:name="androID.intent.category.DEFAulT" /> </intent-filter> </activity> </application> <!-- 在同一应用中访问PhoneActivity也需要加上权限 --> <uses-permission androID:name="scott.permission.MY_CALL_PHONE"/> <uses-sdk androID:minSdkVersion="8" /> </manifest>
需要注意的是,在声明权限时需要一个androID:protectionLevel的属性,它代表“风险级别”。必须是以下值之一:
normal、dangerous、signature、signatureOrSystem。
另外一个是androID:permissionGroup属性,表示一个权限组。可以将权限放在一个组中,但对于自定义权限,应该避免设置此属性。如果确实希望设置此属性,可以使用以下属性代替:androID.permission-group.SYstem_TOolS。
下面是两个活动的截图:
以上过程都是在一个内部完成的,现在假如我们的这个phone应用作为系统内置的应用,做为开发者,我们新建一个app,然后访问phone应用里的PhoneActivity。app的结构图如下:
我们在MainActivity里放置一个按钮,点击之后跳转到phone应用的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文件中配置相应的权限:
<application ...> ... </application> <uses-permission androID:name="scott.permission.MY_CALL_PHONE"/>
点击按钮,就可以顺利地跳转到PhoneActivity了。截图如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的解析Android声明和使用权限全部内容,希望文章能够帮你解决解析Android声明和使用权限所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)