android程序间的数据共享机制,057-跨程序共享数据-Android权限机制

我们之前在讲广播的时候第一次接触了Android权限相关的内容, 当时为了要访问系统的网络状态以及监听开机广播, 于是在AndroidManifest.xml文件中添加了这样两句权限声明:

因为访问系统的网络状态以及监听开机广播涉及了用户设备的安全性, 因此必须在AndroidManifest.xml中加入权限声明, 否则我们的程序就会崩溃。

为什么这样就可以保护用户设备的安全性了呢?

其实用户主要在以下两个方面得到了保护, 一方面, 如果用户在低于6.0系统的设备上安装该程

序, 会在安装界面给出如图7.1所示的提醒。 这样用户就可以清楚地知晓该程序一共申请了哪些

权限, 从而决定是否要安装这个程序。

安装界面的权限提醒

18b4ab863f72da2585a0768dc91a0d61.png

另一方面, 用户可以随时在应用程序管理界面查看任意一个程序的权限申请情况, 如图7.2所

示。 这样该程序申请的所有权限就尽收眼底, 什么都瞒不过用户的眼睛, 以此保证应用程序不

会出现各种滥用权限的情况。

9629e7d3b55127196d4b89780a60ed0e.png

但是理想是美好的, 现实却很残酷, 因为很多我们所离不开的常用软件普遍存在着滥用权限的

情况, 不管到底用不用得到, 反正先把权限申请了再说。 比如说微信所申请的权限列表如图7.3

所示

02693c5c997568cb211998a68cead049.png

Android开发团队当然也意识到了这个问题, 于是在6.0系统中加入了运行时权限功能。 也就是

说, 用户不需要在安装软件的时候一次性授权所有申请的权限, 而是可以在软件的使用过程中

再对某一项权限申请进行授权。 比如说一款相机应用在运行时申请了地理位置定位权限, 就算

我拒绝了这个权限, 但是我应该仍然可以使用这个应用的其他功能, 而不是像之前那样直接无

法安装它。

当然, 并不是所有权限都需要在运行时申请, 对于用户来说, 不停地授权也很烦琐。 Android现

在将所有的权限归成了两类, 一类是普通权限, 一类是危险权限。 准确地讲, 其实还有第三类

特殊权限, 不过这种权限使用得很少, 因此不在本书的讨论范围之内。 普通权限指的是那些不

会直接威胁到用户的安全和隐私的权限, 对于这部分权限申请, 系统会自动帮我们进行授权,

而不需要用户再去手动操作了, 比如在BroadcastTest项目中申请的两个权限就是普通权限。 危险

权限则表示那些可能会触及用户隐私或者对设备安全性造成影响的权限, 如获取设备联系人信

息、 定位设备的地理位置等, 对于这部分权限申请, 必须要由用户手动点击授权才可以, 否则

程序就无法使用相应的功能。

但是Android中有一共有上百种权限, 我们怎么从中区分哪些是普通权限, 哪些是危险权限呢?

其实并没有那么难, 因为危险权限总共就那么几个, 除了危险权限之外, 剩余的就都是普通权

限了。 下表列出了Android中所有的危险权限, 一共是9组24个权限。

d559bbe4eb77521ea4d00de79c61b054.png

另外注意一下, 表格中每个危险权限都属于一个权限组, 我们在进行运行时权限处理时使用的

是权限名, 但是用户一旦同意授权了, 那么该权限所对应的权限组中所有的其他权限也会同时

被授权。访问http://developer.android.google.cn/reference/android/Manifest.permission.html 可以查看Android

系统中完整的权限列表。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值