我的Android进阶之旅------>Android声明和使用权限

简介: Android定义了一种权限方案来保护设备上的资源和功能。例如,在默认情况下,应用程序无法访问联系人列表、拨打电话等。下面就以拨打电话为例介绍一下系统对权限的要求。

Android定义了一种权限方案来保护设备上的资源和功能。例如,在默认情况下,应用程序无法访问联系人列表、拨打电话等。下面就以拨打电话为例介绍一下系统对权限的要求。一般在我们的应用中,如果要用到拨打电话的功能,我们会这样编码:

  1. Uri uri = Uri.parse("tel:12345678"); 
  2. Intent intent = new Intent(Intent.ACTION_CALL, uri); 
  3. startActivity(intent); 

默认情况下,我们无权访问拨打电话的Activity,控制台将会报以下异常信息:

  1. ERROR/AndroidRuntime: java.lang.SecurityException: Permission Denial:  
  2. starting Intent { act=android.intent.action.CALL dat=tel:12345678 cmp=com.android.phone/.OutgoingCallBroadcaster } 
  3. ......  
  4. requires android.permission.CALL_PHONE 

看来,我们是缺少了CALL_PHONE这个权限,这个权限是Android系统自带的phone应用里定义的权限:

  1. ...... 
  2. <uses-permissionandroid:name="android.permission.CALL_PHONE"/> 
  3. ...... 
  4. <activity android:name="OutgoingCallBroadcaster" 
  5.                 android:permission="android.permission.CALL_PHONE" 
  6.                 android:theme="@android:style/Theme.NoDisplay" 
  7.                 android:configChanges="orientation|keyboardHidden"> 
  8.             <!-- CALL action intent filters, for the various ways 
  9.                  of initiating an outgoing call. --> 
  10.             <intent-filter> 
  11.                 <actionandroid:name="android.intent.action.CALL"/> 
  12.                 <categoryandroid:name="android.intent.category.DEFAULT"/> 
  13.                 <dataandroid:scheme="tel"/> 
  14.             </intent-filter> 
  15.             <intent-filter> 
  16.                 <actionandroid:name="android.intent.action.CALL"/> 
  17.                 <categoryandroid:name="android.intent.category.DEFAULT"/> 
  18.                 <dataandroid:scheme="voicemail"/> 
  19.             </intent-filter> 
  20.             <intent-filter> 
  21.                 <actionandroid:name="android.intent.action.CALL"/> 
  22.                 <categoryandroid:name="android.intent.category.DEFAULT"/> 
  23.                 <dataandroid:mimeType="vnd.android.cursor.item/phone"/> 
  24.                 <dataandroid:mimeType="vnd.android.cursor.item/phone_v2"/> 
  25.                 <dataandroid:mimeType="vnd.android.cursor.item/person"/> 
  26.             </intent-filter> 
  27. </activity> 
  28. ...... 

想要使用此功能,必须在我们的AndroidManifest.xml文件中声明使用此权限:

  1. <application ...> 
  2. ... 
  3. </application> 
  4. <uses-permissionandroid:name="android.permission.CALL_PHONE"/> 

这告诉系统,我们的应用使用了此权限,我们有权访问拨打电话的Activity。

我们不仅要问,为什么系统会这样设计呢?答案是为了保护用户资源的安全。要想使用此功能,必须在应用中声明权限信息,这样一来,在用户安装此应用时系统会从应用中提取出权限信息,告诉用户该应用使用到了哪些功能,由用户判断该应用是否损害自己的安全。

接下来由我来演示一下权限的定义和使用,我们建立一个phone项目,项目结构如下:

我们设计的流程是在MainActivity中点击按钮,然后跳转到PhoneActivity中,我们会为PhoneActiivty定义相应的权限。

我们先看一下MainActivity和PhoneActivity的代码:

MainActivity.java如下:

  1. package com.scott.phone; 
  2.  
  3. import android.app.Activity; 
  4. import android.content.Intent; 
  5. import android.os.Bundle; 
  6. import android.view.View; 
  7. import android.widget.Button; 
  8.  
  9. public class MainActivityextends Activity { 
  10.     @Override 
  11.     public void onCreate(Bundle savedInstanceState) { 
  12.         super.onCreate(savedInstanceState); 
  13.         setContentView(R.layout.main); 
  14.         Button btn = (Button) findViewById(R.id.btn); 
  15.         btn.setOnClickListener(new View.OnClickListener() { 
  16.             @Override 
  17.             public void onClick(View v) { 
  18.                 startActivity(new Intent(MainActivity.this, PhoneActivity.class)); 
  19.             } 
  20.         }); 
  21.     } 

PhoneActivity.java如下:

  1. package com.scott.phone; 
  2.  
  3. import android.app.Activity; 
  4. import android.os.Bundle; 
  5. import android.widget.TextView; 
  6.  
  7. public class PhoneActivityextends Activity { 
  8.     @Override 
  9.     protected void onCreate(Bundle savedInstanceState) { 
  10.         super.onCreate(savedInstanceState); 
  11.         TextView tv = new TextView(this); 
  12.         tv.setText("Yes! It works."); 
  13.         setContentView(tv); 
  14.     } 
 

最重要的是AndroidManifest.xml文件,我们所有的权限声明配置都在此文件中完成:

  1. <?xmlversion="1.0"encoding="utf-8"?> 
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android" 
  3.       package="com.scott.phone" 
  4.       android:versionCode="1" 
  5.       android:versionName="1.0"> 
  6.      
  7.     <!-- 声明一个权限  --> 
  8.     <permissionandroid:protectionLevel="normal"  
  9.                 android:name="scott.permission.MY_CALL_PHONE"/> 
  10.                  
  11.     <applicationandroid:icon="@drawable/icon"android:label="@string/app_name"> 
  12.         <activityandroid:name=".MainActivity" 
  13.                   android:label="@string/app_name"> 
  14.             <intent-filter> 
  15.                 <actionandroid:name="android.intent.action.MAIN"/> 
  16.                 <categoryandroid:name="android.intent.category.LAUNCHER"/> 
  17.             </intent-filter> 
  18.         </activity> 
  19.         <!-- 为Activity应用已定义的权限 --> 
  20.         <activityandroid:name=".PhoneActivity"  
  21.                   android:permission="scott.permission.MY_CALL_PHONE"> 
  22.             <intent-filter> 
  23.                 <!-- 注意这个action 在其他应用中可使用此action访问此Activity --> 
  24.                 <actionandroid:name="scott.intent.action.MY_CALL"/> 
  25.                 <categoryandroid:name="android.intent.category.DEFAULT"/> 
  26.             </intent-filter> 
  27.         </activity> 
  28.     </application> 
  29.     <!-- 在同一应用中访问PhoneActivity也需要加上权限 --> 
  30.     <uses-permissionandroid:name="scott.permission.MY_CALL_PHONE"/> 
  31.     <uses-sdkandroid:minSdkVersion="8"/> 
  32. </manifest> 

需要注意的是,在声明权限时需要一个android:protectionLevel的属性,它代表“风险级别”。必须是以下值之一:

normal、dangerous、signature、signatureOrSystem。

normal表示权限是低风险的,不会对系统、用户或其他应用程序造成危害。

dangerous表示权限是高风险的,系统将可能要求用户输入相关信息,才会授予此权限。

signature告诉Android,只有当应用程序所用数字签名与声明此权限的应用程序所有数字签名相同时,才能将权限授给它。

signatureOrSystem告诉Android,将权限授给具有相同数字签名的应用程序或Android包类,这一级别适用于非常特殊的情况,比如多个供应商需要通过系统影像共享功能时。

另外一个是android:permissionGroup属性,表示一个权限组。可以将权限放在一个组中,但对于自定义权限,应该避免设置此属性。如果确实希望设置此属性,可以使用以下属性代替:android.permission-group.SYSTEM_TOOLS。

下面是两个活动的截图:

以上过程都是在一个内部完成的,现在假如我们的这个phone应用作为系统内置的应用,做为开发者,我们新建一个app,然后访问phone应用里的PhoneActivity。app的结构图如下:

我们在MainActivity里放置一个按钮,点击之后跳转到phone应用的PhoneActivity中。MainActivity.java代码如下:

  1. package com.scott.app; 
  2.  
  3. import android.app.Activity; 
  4. import android.content.Intent; 
  5. import android.os.Bundle; 
  6. import android.view.View; 
  7. import android.widget.Button; 
  8.  
  9. public class MainActivityextends Activity { 
  10.     @Override 
  11.     public void onCreate(Bundle savedInstanceState) { 
  12.         super.onCreate(savedInstanceState); 
  13.         setContentView(R.layout.main); 
  14.         Button btn = (Button) findViewById(R.id.btn); 
  15.         btn.setOnClickListener(new View.OnClickListener() { 
  16.             @Override 
  17.             public void onClick(View v) { 
  18.                 Intent intent = new Intent("scott.intent.action.MY_CALL"); 
  19.                 startActivity(intent); 
  20.             } 
  21.         }); 
  22.     } 

然后我们需要在AndroidManifest.xml文件中配置相应的权限:

  1. <application ...> 
  2. ... 
  3. </application> 
  4. <uses-permissionandroid:name="scott.permission.MY_CALL_PHONE"/> 

点击按钮,就可以顺利地跳转到PhoneActivity了。截图如下:

本文转载于:http://blog.csdn.net/liuhe688/article/details/6417983

相关文章
|
24天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
|
5月前
|
存储 安全 Android开发
"解锁Android权限迷宫:一场惊心动魄的动态权限请求之旅,让你的应用从平凡跃升至用户心尖的宠儿!"
【8月更文挑战第13天】随着Android系统的更新,权限管理变得至关重要。尤其从Android 6.0起,引入了动态权限请求,增强了用户隐私保护并要求开发者实现更精细的权限控制。本文采用问答形式,深入探讨动态权限请求机制与最佳实践,并提供示例代码。首先解释了动态权限的概念及其重要性;接着详述实现步骤:定义、检查、请求权限及处理结果;最后总结了六大最佳实践,包括适时请求、解释原因、提供替代方案、妥善处理拒绝情况、适应权限变更及兼容旧版系统,帮助开发者打造安全易用的应用。
92 0
|
8月前
|
API Android开发
Android高手进阶教程(十五)之---通过Location获取Address的使用!
Android高手进阶教程(十五)之---通过Location获取Address的使用!
93 1
|
4月前
|
存储 API Android开发
"解锁Android权限迷宫:一场惊心动魄的动态权限请求之旅,让你的应用从平凡跃升至用户心尖的宠儿!"
随着Android系统的更新,权限管理成为应用开发的关键。尤其在Android 6.0(API 级别 23)后,动态权限请求机制的引入提升了用户隐私保护,要求开发者进行更精细的权限管理。
87 2
|
8月前
|
Java Shell Android开发
android 权限申请
android 权限申请
141 5
|
7月前
|
存储 算法 Java
Android 进阶——代码插桩必知必会&ASM7字节码操作
Android 进阶——代码插桩必知必会&ASM7字节码操作
359 0
|
8月前
|
缓存 网络协议 Java
挑战全网,史上最全Android开发进阶,跳槽复习指南(1),掌握这6大技能体系
挑战全网,史上最全Android开发进阶,跳槽复习指南(1),掌握这6大技能体系
|
8月前
|
算法 安全 Java
2024年Android最新知识体系最强总结(全方面覆盖Android知识结构,BAT面试&学习进阶)
2024年Android最新知识体系最强总结(全方面覆盖Android知识结构,BAT面试&学习进阶)
|
8月前
|
消息中间件 缓存 架构师
2024年阿里Android高级面试题分享,附学习笔记+面试整理+进阶书籍
2024年阿里Android高级面试题分享,附学习笔记+面试整理+进阶书籍
|
8月前
|
XML API 数据库
Android权限
Android权限 【5月更文挑战第3天】
126 0

热门文章

最新文章