Android中installd进程存在的意义

1. 为什么需要installd

从下面的输出可以看出,system_server以system用户的身份运行。我们知道,PackageManager运行于system_server中。也就是说,PackageManager的身份也是system用户。

[email protected]:/$ busybox ps

busyboxps

PID   USER    TIME   COMMAND

……

701 system    0:23 system_server

146 install   0:00 /system/bin/installd

但是,system用户并没有访问应用程序目录的权限。下面的输出显示当前用户是system,它不能访问/data/data/com.xiaomi.shop目录(此目录应为小米应用程序商店应用的目录)。

[email protected]:/data/data$ id

id

uid=1000(system) gid=1000(system)context=u:r:toolbox:s0

[email protected]:/data/data$ ls -l com.xiaomi.shop

ls -lcom.xiaomi.shop

opendir failed, Permission denied

这就是installd存在的原因。

2.  Installd为什么可以访问应用程序的目录(比如/data/data/com.xiaomi.shop)?

installd的源程序在frameworks\native\cmds\installd目录下。

在install.c文件中有下面的代码。

static void drop_privileges() {

……

struct __user_cap_header_struct capheader;

struct __user_cap_data_struct capdata[2];

memset(&capheader, 0,sizeof(capheader));

memset(&capdata, 0, sizeof(capdata));

capheader.version =_LINUX_CAPABILITY_VERSION_3;

capheader.pid = 0;

capdata[CAP_TO_INDEX(CAP_DAC_OVERRIDE)].permitted |= CAP_TO_MASK(CAP_DAC_OVERRIDE);

……

if (capset(&capheader, &capdata[0])< 0) {

ALOGE("capset failed: %s\n",strerror(errno));

exit(1);

}

}

int main(const int argc__unused, const char *argv[] __unused) {

……

drop_privileges();

……

}

从上面的代码中可以看出,installd进程具有CAP_DAC_OVERRIDE特权(Privilege)。根据http://linux.die.net/man/7/capabilities, 对于具有CAP_DAC_OVERRIDE特权的进程,Linux会跳过文件的读、写、执行权限的检查。所以,installd可以访问任何目录下的文件。

CAP_DAC_OVERRIDE

Bypass file read, write, and executepermission checks. (DAC is an abbreviation of "discretionary accesscontrol".)

时间: 2024-07-31 12:46:35

Android中installd进程存在的意义的相关文章

Android中通过进程注入技术修改广播接收器的优先级

前言 这个周末又没有吊事,在家研究了如何通过进程的注入技术修改广播接收器的优先级,关于这个应用场景是很多的,而且也很重要,所以就很急的去fixed了. Android中的四大组件中有一个广播:Broadcast 关于它的相关知识可以转战:http://blog.csdn.net/jiangwei0910410003/article/details/19150705 我们这里就不做太多解释了,现在来看一下问题: 知识前提 这篇文章和我之前介绍一篇文章: Andrdoid中对应用程序的行为拦截实现方

总结android中的进程

android中进程的层次如下(重要性由高到低): 1.前端进程.顾名思义,前端进程就是目前显示在屏幕上和用户交互的进程,在系统中前端进程数量很少,而这种进程是对用户体验的影响最大,只有系统的内存稀少到不足以维持和用户的基本交互时才会销毁前端进程.因此这种进程重要性是最高的. 2.可见进程.可见进程也拥有一个可视化的界面,只是目前不是最上层界面(最上层界面在前端进程里面),可见进程一般调用了OnPause(),可见进程比前端进程重要性低,但是在交互方面影响还是很大,因为用户可能随时切换过去,所以

Android中的进程

每个Android程序默认情况下只有一个进程,这个进程是在自己独立的空间中运行,默认拥有独立的Dalvik虚拟机实例.每一个DVM都是Linux中的一个进程,所以可以认为Android dvm的进程和Linux的进程, 应用程序的进程是同一概念. 但是也可以指定Activity或者Service在Remote 进程中执行.多数情况下,只有在用户认为应用退出后还需要继续后台长期运行的应用,才需要这样做.此时,该应用有两个进程. 如何退出进程 1.System.exit(0)  这个方法是用来结束当

android中的进程级别

Android中,同一个应用的所有组件在默认情况下都运行在同一个进程中,但也可以通过修改manifest文件中的android:process属性来指定该组件要运行中那个进程,也可以让不同应用的组件们运行在同一个进程中,当然这些应用要共享一个用户ID并并且有相同的数字证书. Android可能在某个时刻决定关闭一个进程,当决定要关闭那些进程的时候,系统会衡量每个进程与用户的紧密程度,这时候就跟Android中进程的级别有关了.像一个具有可见的activity的进程要比那些activity都是不可

Android中通过进程注入技术修改系统返回的Mac地址

致谢 感谢看雪论坛中的这位大神,分享了这个技术:http://bbs.pediy.com/showthread.php?t=186054,从这篇文章中学习到了很多内容,如果没有这篇好文章,我在研究的过程中会遇到很多困难,说不定我就放弃了~~在此感谢他. 前言 之前的几篇文章都是在介绍了OC的相关知识,之前的半个月也都是在搞IOS的相关东西,白天上班做Android工作,晚上回家还有弄IOS,感觉真的很伤了.不过OC的知识也学习了差不多了.不过在这段时间遗留了很多Android方面的问题都没有进行

Android中的进程和线程,-&gt;View.post(Runnable) -&gt;AsyncTask

写在前面的话 一个Android应用就是一个Linux进程,每个应用在各自的进程中运行,互不干扰,比较安全. 一个应用对应一个主线程,就是通常所说的UI线程,android遵守的就是单线程模型,所以说Ui操作不是线程安全的并且这些操作必须在UI线程中执行. 本文是对官方文档的翻译,原文链接:https://developer.android.com/guide/components/processes-and-threads.html 概述 当某个应用组件启动且该应用没有运行其他任何组件时,An

Android中的进程和线程

写在前面的话 一个Android应用就是一个Linux进程,每个应用在各自的进程中运行,互不干扰,比较安全. 一个应用对应一个主线程,就是通常所说的UI线程,android遵守的就是单线程模型,所以说Ui操作不是线程安全的并且这些操作必须在UI线程中执行. 本文是对官方文档的翻译,原文链接:https://developer.android.com/guide/components/processes-and-threads.html 概述 当某个应用组件启动且该应用没有运行其他任何组件时,An

Android中的UID和PID意义,及查看方式

Pid是进程ID,Uid是用户ID,只是Android和计算机不一样,计算机每个用户都具有一个Uid,哪个用户start的程序,这个程序的Uid就是那个用户,而Android中每个程序都有一个Uid,默认情况下,Android会给每个程序分配一个普通级别互不相同的 Uid,如果用互相调用,只能是Uid相同才行,这就使得共享数据具有了一定安全性,每个软件之间是不能随意获得数据的.而同一个application 只有一个Uid,所以application下的Activity之间不存在访问权限的问题.

android中杀死进程的方法

第一种方法:这个方法只能自杀,不能杀死其他进程~ /**************************************************** *            杀死进程的第一种方法                   * *                                                   * ****************************************************/ int myPid = android