Android:java.io.IOException: Cannot run program "/system/xbin/su": error=13, Permission denied

  • java.io.IOException: Cannot run program "/system/xbin/su": error=13, Permission denied

 

  • 我的情况

同一套App程序,之前跑在Android4.0中没有这个问题,这个问题是在新的安卓板,跑的是Android7.1.2系统中发现的,我第一个反应就是权限不够,但是即使进入安卓设备中的命令行用"chmod"命令修改权限成功,也无法解决这个问题,这个问题经过网上其他资料了解到,在5.0版本之后,下面这种方式已经不能获取root权限了.

Process su = Runtime.getRuntime().exec("/system/xbin/su");

这里临时解决方案是使用adb工具,临时修改系统的参数设置:

adb root
adb shell setenforce 0

注意要先进行"adb root"操作,否则,执行"adb shell setenforce 0"操作的时候会报错:

setenforce: Couldn't set enforcing status to '0': Permission denied

如果要永久的设置,需要修改系统启动参数,加入"androidboot.selinux=permissive"这样的设置,这里暂时还没有尝试,不过接下来我会去尝试的.

虽然这个问题解决了,但是我想要的结果并没有达到,因为虽然没有这个问题了,也能执行获取root权限的命令了,但是结果却返回的是1,这个是说明命令执行失败的,原因是这个操作不被系统所允许.这个现象说明了su程序虽然能被调用了,但是su程序执行过程中失败了,怎么办?没错,接下来就修改su源代码吧,不过这里我没有仅仅修改su的源码,而是参考了额外说明中的网站,对系统源码进行了修改,并重新编译系统,相关内容在我的这篇博客中:

https://blog.csdn.net/uestc_ganlin/article/details/90673527

  • 额外说明

以下内容,参考自:https://blog.csdn.net/kangear/article/details/51872653.

Android4.2.2(Jelly Bean)上,调用su命令就可以获取到root权限并执行一些命令.但是在Android4.3之上的版本,Google为这种获取root权限的方法设置了层层障碍:

1.su命令源码中添加了uid检验,只允许shell/root用户进行调用;

2.Zygote源码中添加了一些东西,屏蔽掉了App可以进行setuid的功能;

3.adb源码中添加了一些东西,屏蔽掉了adb可以进行setuid的功能(这里指的是对于非userdebug等类似版本的系统) ;

4.开启了SELinux安全模块,1和2条都满足情况下也会中断su命令的执行.
 

你可能感兴趣的:(Android)