Android 下应用程序不能直接 获得 root 权限,因此如果需要修改 /sys /proc 等目录下的文件时,有以下两种方法可以选择:

  1. 通过 service 或虚拟设备的方法将使得应用程序临时 获得 root 权限
  2. /sys /proc 目录下的文件修改访问权限,使得它们能够被程序访问

对于方法 1 ,可以参看我后续会写到的一篇文章《如何使 Android 应用程序获得 root 权限》,也可以在网上搜索别的相关文章。

这里讲讲方法 2

为了理解方法 2 ,首先要知道 Android 上的权限机制。 Android 会为每个安装在系统上的包( apk )配一个唯一的 linux userID ,名称为 "app_" 加一个数字,比如 app_43 。这样该应用程序的文件只对该用户可见,也就是说,应用程序只能访问相同 uid gid 的文件。

另外,也可以通过 AndroidManifest.xml 修改应用程序的 uid 。如果将 android:sharedUserId 项的值改为其它 apk java package name ,则该应用程序和所指定的应用程序拥有相同的 uid ,可以访问对方的文件。

通过 android:sharedUserId 还可以将应用程序提升为 system 权限。

有了上面的知识,这里有三种方法来修改我们所要访问的文件:

  1. 将文件改为 777 权限
  2. 将文件改为 apk uid gid
  3. 将文件修改为 system uid ,同时将 apk 也提升为 system 权限

这三种方法都需要修改所要访问系统文件的权限。要更改权限,在 init.rc 文件中添加相应的命令即可。下述命令就将 /dev/cpuctl/tasks 修改为 system uid gid ,并且将其权限更改为 777

chown system system /dev/cpuctl/tasks

chmod 0777 /dev/cpuctl/tasks

修改 init.rc 该文件需要修改 ramdisk.img ,具体修改方法可以网上搜索,也可以参看这篇文章最后的附录。或者在源代码中直接修改 init.rc 文件然后编译即可。

下面依次分析一下上面提到的三种修改访问文件的方法。第一种方法是最简单的,不过安全性不好,仅仅可以作为实验使用,不推荐;第二种方法将系统文件文件的 uid 修改后,拓展性不好,并且我不能确定每次分配给 apk uid 是否相同。我这里试了几次,重新安装后 apk uid 都是相同的,不过没有找到相关文章,所以不敢用。最后我这里采用第三种方法实现。

1)首先修改 init.rc

chown system system /sys/bus/usb/devices/testfile

这样每次启动后,系统都会执行 init.rc 文件将 testfile uid 修改为 system ,这样 uid 同问 system 的程序就能够访问该文件了。

2) 其次将 apk 提升为 system 权限

apk 提升为 system 权限需要目标系统中的签名文件对 apk 进行签名,因此这种方法仅适用于某个 rom ,不能用于所有 rom

具体的提升办法网上有很多,这里不再多说,可以参考这两篇文章:

http://blog.csdn.net/liujian885/archive/2010/03/22/5404834.aspx

http://labs.chinamobile.com/mblog/532767_73183

至此,我们的目标就达成了。

修改 ramdisk.img 的方法

在网上找到了一些修改 ramdisk.img 的方法,都有点问题,我这里写一下自己的流程。由于 ramdisk.img 是首先用 cpio 打包,再用 gzip 压缩后的文件,因此在解压和压缩时都需要经历这两个步骤。

1) mv ramdisk.img ramdisk.img.gz

2) gunzip ramdisk.img.gz #gunzip 解压得到 ramdisk.gz

3) cpio –iI ramdisk.gz # cpio 解压上一步得到的文件

4) 修改 init.rc

5) find. | cpio –o –H newc | gzip -9 > ramdisk.gz #cpio 打包后, gzip 再压缩

6) mv ramdisk.gz ramdisk.img

更多相关文章

  1. 解读Android LOG机制的实现:(5)获取LOG的应用程序LogCat
  2. Android 6.0动态权限,单个申请与多个同时申请
  3. android使用webview预览png,pdf,doc,xls,txt,等文件
  4. Android读取工程内嵌资源文件的两种方法
  5. Android Intent:不同应用程序之间通信的桥梁
  6. Android 共享内存实现跨进程大文件传输(设计思路和Demo实现绕过B
  7. 创建可访问的Android应用程序:辅助技术

随机推荐

  1. Android之LayoutInflater了解(20190109)
  2. Android(安卓)中文 API (19) ―― TwoLineL
  3. adb pull命令复制android数据库文件.db到
  4. Android(安卓)Shape绘制实用圆圈
  5. Android(安卓)为应用创建、删除桌面快捷
  6. Android(安卓)-- AppWidget 进阶篇
  7. android 代码混淆proguard
  8. Tinker
  9. android HorizontalScrollView的简单使用
  10. ROOT android 原理。 基于(zergRush)