RootExplorer怎么样获取root权限的

RootExplorer怎么样获取root权限的

Android系统上面有名的RootExplorer很强大,可以操作任何目录下的文件,包括像/data/data这样需要root权限才能访问的地方。它是怎么样做到的呢?

这里要先提一个开源项目,地址是:http://code.google.com/p/superuser/

大家可以用SVN把源码下载到本地,与系统源码一起编译就可以了。

编译完成后会生成两个文件,一个是二进制可执行文件su,另一个是Superuser.apk。把su复制到系统的/system/bin目录,再把Superuser.apk复制到系统的/system/app目录。

这样,就可以用下面的代码执行su命令时,就会启动Superuser.apk中的Activity弹出标题为“以下程序要求授予最高权限...”的对话框,用户同意之后,APK就有ROOT权限了。

下面看看APK里面的代码。

ProcessBuilder pb = new ProcessBuilder("/system/bin/sh");
pb.directory(new File("/"));//设置shell的当前目录。
try {
    Process proc = pb.start();
//获取输入流,可以通过它获取SHELL的输出。
    BufferedReader in = new BufferedReader(new InputStreamReader(proc.getInputStream()));
    BufferedReader err = new BufferedReader(new InputStreamReader(proc.getErrorStream()));
//获取输出流,可以通过它向SHELL发送命令。
    PrintWriter out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(proc
                    .getOutputStream())), true);
    out.println("pwd");
    out.println("su root");//执行这一句时会弹出对话框(以下程序要求授予最高权限...),要求用户确认。
    out.println("cd /data/data");//这个目录在系统中要求有root权限才可以访问的。
    out.println("ls -l");//这个命令如果能列出当前安装的APK的数据文件存放目录,就说明我们有了ROOT权限。
out.println("exit");
    // proc.waitFor();
String line;
while ((line = in.readLine()) != null) {
  System.out.println(line);
}
while ((line = err.readLine()) != null) {
  System.out.println(line);
}
in.close();
out.close();
proc.destroy();
} catch (Exception e) {
System.out.println("exception:" + e);
}

有了root权限,再结合ls,cp,mv等命令,整个系统的所有目录都可以操作了。

有一些问题目前还没有找到答案:
如果我用ADB从Ubuntu上面执行su root,用户在弹出的对话框上选同意的话,命令会很快返回,接下面提示符就变成#了。
但是,我用代码在APK里面测试的时候,只是偶尔会成功,发现大部分时候会卡死在out.println("su root");这一句上。即,用户在对话框上面选同意后程序没有响应,DDMS也看不到输出。再等上一会儿,程序无响应需要强制关闭的对话框就出来了。这个项目还是不完善的地方,不过思路真的不错。

su程序和Superuser.apk是如何配合让APK运行时具有root权限的。

1、APK中调用su命令
2、su检索数据库(/data/data/com.koushikdutta.superuser/databases/superuser.sqlite),如果找到记录的话,说明当前进程已经被用户允许获取ROOT权限,则进行第4步。
3、如果没有检索到的话,su会通过am start命令打开Superuser.apk中的SuperuserRequestActivity:

sprintf(sysCmd, "am start -a android.intent.action.MAIN -n com.koushikdutta.superuser/com.koushikdutta.superuser.SuperuserRequestActivity --ei uid %d --ei pid %d > /dev/null", g_puid, ppid);
if (system(sysCmd))
    returnexecutionFailure("am.");
然后进入循环等待,每隔一秒检索一次数据库是否有更新,等待的时间是10秒:

for (i = 0; i < 10; i++)
{
sleep(1);
// 0 means waiting for user input
// > 0 means yes/always
// < 0 means no
int checkResult = checkWhitelist();
... ...


而SuperuserRequestActivity会显示界面要求用户选择是否同意进程获取ROOT权限。用户同意的话,就会把当前进程ID加入数据库,并退出Activity。否则,跳到第5步。
4、su在数据库中检索到进程ID的话,说明当前进程已经被用户允许获取ROOT权限,则改变当前进程的用户ID和组ID:

if(setgid(gid) || setuid(uid))
return permissionDenied();


5、命令执行完毕,进程结束。

另外,安装在系统中的APK每次运行时所使用的进程ID号是固定的。

 http://www.surfaceflinger.com/forum.php?mod=viewthread&tid=6&page=1


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RE浏览器(Root Explorer)是一款安卓手机专用的文件管理器,在获取系统ROOT权限后能对系统里的任何文件进行操作,能够轻而易举的删除手机系统程序和删不掉的程序,也可以作为普通的文件管理软件使用。 RootExplorer需要ROOT权限,新建文件夹,查看/编辑文件,软件安装,RootExplorer具备普通文件管理器的各项基本功能,另外还 添加了搜索功能,在手机上找东西变得更加方便。此外,RootExplorer最大的特点在于它能够删除手机中自带的应用程序,如 GOOGLEMAP,CONTACTS,MARKET,GTALK等等。 RE浏览器(Root Explorer)功能说明 - 三种列表视图方式:简洁列表、详细列表、图标,多选文件管理:复制、移动、删除 - 五种文件排序方式:名称升序/降序、日期升序/降序、大小升序/降序、类型 - 更改文件和文件夹的所有者/用户组,创建文件/文件夹的主屏幕快捷方式 - 创建文件/文件夹的符号链接(Symlinks)挂载系统分区的只读/读写权限 - 书签和首页功能:将某个目录设为书签或首页,方便快速打开文件夹 - 查看SQLite数据库文件,计算文件的MD5值,查看文件的MIME类型 - 设置文件和文件夹的读/写/执行权限和特殊权限(SUID/SGID/SBIT) - 删除系统自带应用,对系统文件进行操作,查看和编辑文本文件 - 常用的文件管理功能,完全可自定义的列表图标,多标签页管理 - 查看/解压/创建Zip/Tar/Gzip文件,以及查看和解压RAR文件 - 显示图像缩略图,显示APK文件的图标,快速搜索文件 - 网络(SMB)、Google云端硬盘、Box、Dropbox支持 - 可在后台同时处理多个操作,显示隐藏文件和文件夹 - 设置特定文件类型的打开方式(相当于文件关联) RE浏览器(Root Explorer)更新内容 增加 xxhdpi 和 xxxhdpi 分辨率图标支持。 添加外置 SD 卡时,增加对 64 GB exFAT SD卡的识别。 修正Box网盘中反复出现的身份验证请求。 修正在Android 4.4上搜索内部存储时的问题。 修正默认外部 SD 卡路径。这个问题可能导致部分设备复制文件时出错。 修正使用RE管理器来选择文件上传到 web 站点不是立即启动。 RE浏览器(Root Explorer)截图
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值