同一套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命令的执行.