`

android2.3权限问题

 
阅读更多


    android2.3相对于2.2来说,有个最大的变化就是权限管理模块的更新,导致明明有root权限,但是无法执行很多底层命令和api,举例:在终端上su到root用户,执行ls等命令都会报没有权限。
    该问题引发的问题包括:
    A 大多数PC客户端(包括91助手、豌豆夹等)都无法自动安装daemon程序
    B 很多需要root权限执行的程序无法正常运行


    那么就到底是什么原因导致的呢? 这些权限问题又如何来解决呢? 下面我们先分析一下权限的设计:

    


    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>

    这次就碰到fd = socket(AF_INET, type, 0);打开失败,其实就是这个文件的格式发生变化,应该是utf-8,但是却

    不知为何变成了unicode格式导致xml解析错误,从而获取不到group gid,其为空值导致框架层检测权限失败。

    


    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)        相关源码实现 www.2cto.com
    frameworks/base/services/java/com/android/server/PackageManagerService.java
    frameworks/base/services/java/com/android/server/am/ActivityManagerService.java

    检查权限的代码片段:

        public int checkPermission(String permName, String pkgName) {
            synchronized (mPackages) {
                PackageParser.Package p = mPackages.get(pkgName);
                if (p != null && p.mExtras != null) {
                    PackageSetting ps = (PackageSetting)p.mExtras;
                    if (ps.sharedUser != null) {
                        if (ps.sharedUser.grantedPermissions.contains(permName)) {
                            return PackageManager.PERMISSION_GRANTED;
                        }
                    } else if (ps.grantedPermissions.contains(permName)) {
                        return PackageManager.PERMISSION_GRANTED;
                    }
                }
            }
            return PackageManager.PERMISSION_DENIED;
        }


        public int checkUidPermission(String permName, int uid) {
            synchronized (mPackages) {
                Object obj = mSettings.getUserIdLP(uid);
                if (obj != null) {
                    GrantedPermissions gp = (GrantedPermissions)obj;
                    if (gp.grantedPermissions.contains(permName)) {
                        return PackageManager.PERMISSION_GRANTED;
                    }
                } else {
                    HashSet<String> perms = mSystemPermissions.get(uid);
                    if (perms != null && perms.contains(permName)) {
                        return PackageManager.PERMISSION_GRANTED;
                    }
                }
            }
            return PackageManager.PERMISSION_DENIED;
        }

    

    

    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);

    


    代码片段如下:

                int uid = app.info.uid;
                int[] gids = null;
                try {
                    gids = mContext.getPackageManager().getPackageGids(
                            app.info.packageName);
                } catch (PackageManager.NameNotFoundException e) {
                    Slog.w(TAG, "Unable to retrieve gids", e);
                }

    

     摘自 andyhuabing的专栏
    
分享到:
评论

相关推荐

    android 2.3 sdk android-2.3-sdk

    开发者需要关注API兼容性问题,使用Support Library或者条件编译来确保应用能在不同版本的Android设备上运行。 五、开发流程 1. 创建项目:在IDE中选择Android工程模板,设定目标API为2.3。 2. 设计界面:使用XML...

    android2.3 launcher分析三

    【Android 2.3 Launcher 分析】 Android 2.3 的 Launcher 是用户界面的核心部分,它作为设备的主要入口,提供用户访问应用程序、小部件和设置的界面。在深入分析之前,我们先了解一下 Launcher 的基本架构。 **...

    Ubuntu平台下Android2.3源码下载编译全过程

    在Ubuntu平台上编译Android 2.3源码是一项复杂的过程,需要遵循一系列步骤。首先,确保你的系统满足必要的要求,即运行Ubuntu 10.04或更新版本,并且是64位系统。同时,安装Java Development Kit (JDK) 1.6或更高...

    Android2.3 帮助文档

    在"Android2.3 帮助文档.chm"中,读者可以找到关于这些特性和功能的详细解释,包括如何使用、如何开发和如何优化。这个文档通常会包含API参考、开发者指南、用户手册等内容,对于想要深入了解Android 2.3的开发者和...

    Android 2.3应用开发实战 上部分代码

    9. **权限管理**:Android 2.3中的权限管理更加严格,开发者需要在清单文件中声明需要的权限,并在运行时可能需要处理权限请求。 10. **多线程与异步处理**:为了保证用户体验,耗时操作应在后台线程中进行,...

    android2.3系统源码

    这份"android2.3系统源码"的压缩包,包含了构建Android 2.3核心功能的所有源代码,是深入学习Android系统内核、框架层以及应用层开发的关键资源。 1. **系统内核**: Android 2.3基于Linux内核,这是所有Android...

    android2.3 仿 4.0 launcher

    总的来说,【android2.3 仿 4.0 launcher】是一个旨在提升老版本Android用户体验的开源项目。通过这个启动器,用户可以在他们的Android 2.3设备上享受更现代的界面和功能。同时,对于开发者而言,这也是一个学习如何...

    Android 2.3截屏JNI代码

    Android 2.3中的截屏功能可以通过JNI(Java Native Interface)来实现,这是一种在Java程序中调用本地(C/C++)代码的技术。JNI允许开发者利用Java的跨平台特性,同时利用C/C++的强大性能和低级别操作能力。在这个场景下...

    Android2.3 简单照相功能实现

    这个“Android2.3简单照相功能实现”项目,旨在帮助开发者了解如何集成摄像头功能到自己的应用中。我们将深入探讨相关的知识点,以便您能够构建类似的相机应用。 首先,我们需要在AndroidManifest.xml文件中添加...

    Ubuntu-32位机安装编译Android2.3源码及内核

    在整个编译过程中,可能会遇到各种问题,如依赖缺失、权限问题或源码冲突。当遇到这些问题时,务必查阅官方文档、开发者论坛或Stack Overflow等资源,以找到解决方案。 总之,在Ubuntu 32位系统上编译Android 2.3...

    android 2.3 phone apk 源码

    【标题】"Android 2.3 Phone APK 源码" 涵盖了 Android 系统早期版本的电话应用开发细节,对于深入理解 Android 应用架构和系统级组件的交互具有重要意义。源码是软件开发的核心,通过分析源码,我们可以了解整个...

    android2.3可用的java模拟器

    标题中的“android2.3可用的java模拟器”指的是在Android 2.3(Gingerbread)操作系统上能够运行的Java应用程序模拟器。这通常涉及到Java虚拟机(JVM)的实现,因为Java应用程序需要在这样的环境中才能被执行。在...

    android 2.3以后的socket注意

    综上所述,Android 2.3及更高版本对Socket通信提出了更高的要求,开发者需要遵循最佳实践,确保网络操作在合适的线程中执行,并正确处理权限、异常和资源释放等问题。理解并掌握这些知识点对于开发高质量的Android...

    android2.3 launcher分析

    ### Android 2.3 Launcher分析 #### 架构概述 Android 2.3 版本中的Launcher采用的是经典的MVC(Model-View-Controller)架构模式。这种模式将应用程序分为三个核心部分:模型(Model)、视图(View)以及控制器...

    android 2.3 Phone 源码 0分下载

    Android 2.3对电话功能的访问有严格的权限控制。源码中涉及到的权限如READ_PHONE_STATE、CALL_PHONE等,确保只有合法的应用才能进行电话操作,防止恶意软件滥用。 7. **网络通信与数据交换** 在Phone源码中,会...

    Android 2.3 Bluetooth 源码 0分下载

    深入源码,我们还能看到Android如何处理蓝牙的权限管理,如何实现蓝牙适配器的枚举,以及如何在系统层面进行设备的发现和配对。此外,还可以了解Android如何处理蓝牙音频流、数据通道以及如何支持蓝牙低功耗(BLE)...

    Android2.3应用开发实战 下部分代码

    在Android2.3应用开发实战中,我们深入探讨了如何构建高效、功能丰富的应用程序,针对这一版本的Android系统进行优化。作者林城以其丰富的经验,为开发者提供了宝贵的实践指导。本部分主要关注的是代码实现,这通常...

    大胆尝姜饼:HTC Legend G6开刷Android 2.3.doc

    8. **不足之处**:尽管Android 2.3有所进步,但仍存在一些问题,如不支持前置摄像头的视频通话功能,以及在多媒体性能上与iPhone 4相比存在一定差距。 对于HTC Legend G6用户来说,想要体验Android 2.3 Gingerbread...

    Android2.3 系统的兼容性标准规范

    Android 2.3引入了一些新的权限,同时也更新了旧有的权限模型。这要求开发者仔细检查自己的应用是否符合最新的权限要求。 ###### 3.2.2 构建参数 构建参数的变化可能会影响到应用的编译和运行。这部分需要特别关注...

Global site tag (gtag.js) - Google Analytics