1. 权限 每个程序在安装时都有建立一个系统ID,如app_15,用以保护数据不被其它应用获取。Android根据不同的用户和组,分配不同权限,比如访问SD卡,访问网络等等。底层映射为Linux权限。 2. 应用申请权限 1) 应用 ...
1. 权限
每个程序在安装时都有建立一个系统ID,如app_15,用以保护数据不被其它应用获取。Android根据不同的用户和组,分配不同权限,比如访问SD卡,访问网络等等。底层映射为Linux权限。
2. 应用申请权限
1) 应用开发者通过AndroidManifest.
2)如果是缺少某个权限(程序中使用的某种权限而在AndroidManifest.
3)与某个进程使用相同的用户ID应用程序可与系统中已存在的用户使用同一权限,需要在AndroidManifest.
3. Android权限的实现
1)第一层:由应用设置,修改AndroidManifest.
<uses-permission android:name=”android.permission.INTE.NET”/>
2)第二层:框架层,权限对应组,frameworks/base/data/etc/platform.
<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
原标题:Android 权限的实现
关键词:Android
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。