Root的原理介绍
android系统管理员用户就叫做root,该帐户拥有整个系统至高无上的权利,它可以访问和修改你手机几乎所有的文件,只有root才具备最高级别的管理权限。
我们root手机的过程也就是获得手机最高使用权限的过程。同时为了防止不良软件也取得root用户的权限,当我们在root的过程中,还会给系统装一个程序,用来作为运行提示,由用户来决定,是否给予最高权限。这个程序的名字叫做Superuser.apk。当某些程序执行su指令想取得系统最高权限的时候,Superuser就会自动启动,拦截该动作并作出询问,当用户认为该程序可以安全使用的时候,那么我们就选择允许,否则,可以禁止该程序继续取得最高权限。
Root的过程其实就是把su文件放到/system/bin/ Superuser.apk 放到system/app下面,
还需要设置/system/bin/su可以让任意用户可运行,有set uid和set gid的权限。
即要在android机器上运行命令:adb shell chmod 4755 /system/bin/su。而通常,厂商是不会允许我们随便这么去做的,我们就需要利用操作系统的各种漏洞,来完成这个过程。
Root的方法
从Root的原理我们了解到,root过程分三步:
1. a. adb push su /system/bin
2.
3. b. adb push SuperUser.apk /system/app
4.
5. c. adb shell chmod 4755 /system/bin/su
若系统是eng版的,做到以上三步,那么我们Root就大功告成,但实际是不行的。为什么呢?原因有三:
1、user版的/system 路径是只读权限,不能简单写入
2、 chmod需要Root权才能运行(死循环了)
3、有些系统在启动时会自动将su的4755权限设成755,甚至直接删除su
那么针对这种情况,我们怎么办呢?非常简单:烧一个eng版本的boot.img就行了
可以用展讯的烧录工具,或者用fastboot模式从sd卡烧一个boot.img文件即可
至此,我们Root就成功了,可以用R.E(Root Explorer)在根目录创建和删除文件。
三、深入理解Root机制
其流程是:
1. 1. Su 被用户调用
2.
3. 2. Su 创建了一个socket监听
4.
5. 3. Su 向Superuser发送了一个广播,说是有一个程序要请求root
6.
7. 4. Su 等待socket 数据接收。有超时处理。
8.
9. 5. Superuser 界面收到广播后,弹出一个对话框,询问用户
10.
11. 6. Superuser 向传来的数据中的socket写回用户应答结果。
12.
13. 7. Su 根据socket得到的结果处理应该不应该继续执行
14.
15. 8. 完成提权管理
superuser.apk这个程序是root成功后,专门用来管理root权限使用的,防止被恶意程序滥用。
源码地址: http://superuser.googlecode.com/svn/trunk
我们有两点疑问:
1. superuser是怎么知道谁想用root权限?
2. superuser是如何把用户的选择告诉su程序的?
即superuser和su程序是如何通讯的,他们俩位于不通的时空,一个在java虚拟中,一个在linux的真实进程中。
superuser共有两个activity: SuperuserActivity和 SuperuserRequestActivity
其中SuperuserActivity主要是用来管理白名单的,就是记住哪个程序已经被允许使用root权限了,省的每次用时都问用户。
SuperuserRequestActivity 就是用来询问用户目前有个程序想使用root权限,是否允许,是否一直允许,即放入白名单。
这个白名单比较关键,是一个sqlite数据库文件,位置:
/data/data/com.koushikdutta.superuser/databases/superuser.sqlite
上文说过,root的本质就是往 /system/bin/下放一个su文件,不检查调用者权限的su文件。普通程序可以调用该su来运行root权限的命令。
superuser.apk中就自带了一个这样的su程序。一开始superuser会检测/system/bin/su是否存在:
有进程使用root权限,superuser是怎么知道的呢,关键是句:
1. sprintf(sysCmd, "am start -a android.intent.action.MAIN
2.
3. -n com.koushikdutta.superuser/com.koushikdutta.superuser.SuperuserRequestActivity
4.
5. --ei uid %d --ei pid %d > /dev/null", g_puid, ppid);
6.
7. if (system(sysCmd))
8.
9. return executionFailure("am.");
原理是am命令,am的用法:、、、
四、资源文件的获取
从上文的源码地址获取源代码,替换系统的system/extras/su/下面的su.c和Android.mk文件,使用编译命令 ./mk td28 u adr system/extras/su/编译成功后会生成out/target/product/hsdroid/system/xbin/su文件,而Superuser.apk就是普通的apk文件,都在源码地址里面可以下载,下载后倒入到eclipse即可直接运行。
五、总结
在阅读完本文后,可以站在专业的角度了解root的真正原理,