当前位置: 首页 > news >正文

Android 权限的实现

 

1.    权限

 

  每个程序在安装时都有建立一个系统ID,如app_15,用以保护数据不被其它应用获取。Android根据不同的用户和组,分配不同权限,比如访问SD卡,访问网络等等。底层映射为Linux权限。

 

2.    应用申请权限

 

  1) 应用开发者通过AndroidManifest.xml中<uses-permission>指定对应权限,再映射到底层的用户和组,默认情况下不设定特殊的权限。AndroidManifest加入权限后系统安装程序时会在图形界面中提示权限

  2)如果是缺少某个权限(程序中使用的某种权限而在AndroidManifest.xml中并未声名),程序运行时会在logcat中打印出错误信息requires <permission>

  3)与某个进程使用相同的用户ID应用程序可与系统中已存在的用户使用同一权限,需要在AndroidManifest.xml中设置sharedUserId,如android:sharedUserId="android.uid.shared",作用是获得系统权限,但是这样的程序属性只能在build整个系统时放进去(就是系统软件)才起作用,共享ID的程序必须是同一签名的

 

3.    Android权限的实现

 

  1)第一层:由应用设置,修改AndroidManifest.xml,形如:

    <uses-permission android:name=”android.permission.INTERNET”/>

  2)第二层:框架层,权限对应组,frameworks/base/data/etc/platform.xml,形如:

    <permission name=”android.permission.INTERNET”>

        <group gid=inet” />

    </permission>

  3)第三层:系统层,系统的权限,system/core/include/private/android_filesystem_config.h,形如:

  #define AID_INET 3003              建立SOCKET的权限

  ……

  { “inet”, AID_INET, },

 

4.    系统权限

 

  1) 特殊权限的用户

    a)system     uid 1000

    b)radio       uid 1001

  2) 查看可用系统的权限

    $ adb shell

    # pm list permissions

 

5.    framework层对权限的判断

 

  1)相关源码实现

    frameworks/base/services/Java/com/android/server/PackageManagerService.java

    frameworks/base/services/java/com/android/server/am/ActivityManagerService.java

  2)在系统层,如何查看某个应用的权限

    a)在应用进程开启时,ActivityManagerService.java会在logcat中输出该应用的权限,形如:

      I/ActivityManager(1730): Start proc com.anbdroid.phone for restart com.android.phone:pid=2605 uid=1000 gids={3002,3001,3003} ,即它有3001,3002,3003三个权限:访问蓝牙和建立socket

    b)注意:此打印输出在应用第一次启动时。如果进程已存在,需要先把对应进程杀掉,以保证该进程重新启动,才能显示

    c)具体实现,见:

      framewors/base/services/java/com/android/server/am/ActivityManagerService.java的函数startProcessLocked(),其中取其组信息的具本语句是mContext.getPackageManager().getPackageGids(app.info.packageName);

 

6.    参考

 

  http://wenku.baidu.com/view/7754a4360b4c2e3f5727634e.html

 

转自:http://blog.csdn.net/xieyan0811/article/details/6083019

 

转载于:https://www.cnblogs.com/l2rf/p/6604770.html

相关文章:

  • 看《神探夏洛克》经典台词
  • 挂载硬盘,并分区格式化
  • JavaScript中的对象
  • 用vs2015 编译 web app ionic
  • HTTP访问控制(CORS)
  • 02_SimpleTrigger
  • gbdt调参的小结
  • BZOJ 2055: 80人环游世界 [上下界费用流]
  • 给object数组进行排序(排序条件是每个元素对象的属性个数)
  • spring(一) IOC讲解
  • java中字符串数组、字符串、整形之间的转换。
  • Bzoj 1857: [Scoi2010]传送带(三分套三分)
  • 分享一些书籍,方方面面,很多值得一读
  • 吃饭思考
  • 整数在计算机中的表示
  • 《Java编程思想》读书笔记-对象导论
  • 【跃迁之路】【444天】程序员高效学习方法论探索系列(实验阶段201-2018.04.25)...
  • Effective Java 笔记(一)
  • GDB 调试 Mysql 实战(三)优先队列排序算法中的行记录长度统计是怎么来的(上)...
  • in typeof instanceof ===这些运算符有什么作用
  • Mysql数据库的条件查询语句
  • webpack入门学习手记(二)
  • 翻译:Hystrix - How To Use
  • 构造函数(constructor)与原型链(prototype)关系
  • 基于Vue2全家桶的移动端AppDEMO实现
  • 前端每日实战:61# 视频演示如何用纯 CSS 创作一只咖啡壶
  • 探索 JS 中的模块化
  • 智能合约开发环境搭建及Hello World合约
  • ​​​​​​​Installing ROS on the Raspberry Pi
  • #免费 苹果M系芯片Macbook电脑MacOS使用Bash脚本写入(读写)NTFS硬盘教程
  • $var=htmlencode(“‘);alert(‘2“); 的个人理解
  • (003)SlickEdit Unity的补全
  • (2)(2.4) TerraRanger Tower/Tower EVO(360度)
  • (32位汇编 五)mov/add/sub/and/or/xor/not
  • (5)STL算法之复制
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第5节(封闭类和Final方法)
  • (超详细)语音信号处理之特征提取
  • (附源码)ssm基于web技术的医务志愿者管理系统 毕业设计 100910
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (十八)三元表达式和列表解析
  • (十二)python网络爬虫(理论+实战)——实战:使用BeautfulSoup解析baidu热搜新闻数据
  • (数据结构)顺序表的定义
  • (一)VirtualBox安装增强功能
  • (转)socket Aio demo
  • **PHP分步表单提交思路(分页表单提交)
  • .net core 依赖注入的基本用发
  • .NET/C# 编译期能确定的字符串会在字符串暂存池中不会被 GC 垃圾回收掉
  • .NET/C# 在代码中测量代码执行耗时的建议(比较系统性能计数器和系统时间)
  • .net的socket示例
  • .net和jar包windows服务部署
  • .net连接MySQL的方法
  • .net通用权限框架B/S (三)--MODEL层(2)
  • @ComponentScan比较
  • @DependsOn:解析 Spring 中的依赖关系之艺术
  • [ Linux Audio 篇 ] 音频开发入门基础知识