【Android源码】 权限验证分析(二)

本文详细探讨了Android权限验证的源码流程,从ContextImpl和AMS的权限检查,到ActivityManager的checkComponentPermission方法,再到PackageManagerService的checkUidPermission。通过分析,揭示了Android如何基于UID获取应用包信息,以及系统如何在启动时加载和管理权限信息。
摘要由CSDN通过智能技术生成

上一篇介绍了Android权限验证中的一点小知识,这里我们解析源码流程进一步探索权限验证的过程和实现方法。

权限验证时序图

首先我们先来看看权限验证的实现过程,阅读源码能够发现很多地方都有权限校验的代码,ContextImpl,AMS中都有,不过最终都是调用ActivityManager的checkComponentPermission,如下代码

    ActivityManagerService.java

    int checkComponentPermission(String permission, int pid, int uid,
            int owningUid, boolean exported) {
        if (pid == MY_PID) {
            return PackageManager.PERMISSION_GRANTED;
        }
        return ActivityManager.checkComponentPermission(permission, uid,
                owningUid, exported);
    }

在需要进行权限验证的地方加入此段代码,判断访问者是否拥有访问此代码的权限!

接下来我们重点分析ActivityManager的checkComponentPermission

        public static int checkComponentPermission(String permission, int uid,
            int owningUid, boolean exported) {
        // Root, system server get to do everything.
        //获取调用者的PID,如果是ROOT_UID或者SYSTEM_UID则验证通过
        final int appId = UserHandle.getAppId(uid);
        if (appId == Process.ROOT_UID || appId == Process.SYSTEM_UID) {
            return PackageManager.PERMISSION_GRANTED;
        }
        // Isolated processes don't get any permissions.
        // 如果调用者是隔离的,验证不通过
        if (UserHandle.isIsolated(uid)) {
            return PackageManager.PERMISSION_DENIED;
        }
        // If there is a uid that owns whatever is being accessed, it has
        // blanket access to it regardless of the permissions it requires.
        // 如果当前UID不小于0,验证是否与调用者UID相同,相同则验证通过,owningUid默认为-1
        if (owningUid >= 0 && UserHandle.isSameApp(uid, owningUid)) {
            return PackageManager.PERMISSION_GRANTED;
        }
        // If the target is not exported, then nobody else can get to it.
        // exported属性,默认值根据intent-filter来定,存在intent-filter默认值为true,
        // 否则为false,这里如果为false表示不能别其他应用调用,权限验证默认不通过
        if (!exported) {
            /*
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值