在一次开发过程中,想在应用层APP给Android系统的某个文件赋予读写权限。
一般的想法,那应该就是在代码中调用一下Linux命令就可以实现,然后就写了个函数方法,大致如下:
String command = "chmod 666 /dev/ttyS1";
Process process = Runtime.getRuntime().exec("/system/xbin/su"); // 获取su权限
DataOutputStream os = new DataOutputStream(process.getOutputStream());
os.writeBytes(command + "\n");
os.writeBytes("exit\n");
os.flush();
process.waitFor();
正常来说,调用上面的代码来执行就可以给这个/dev/ttyS1文件赋予读写权限了,但是事情往往没有那么简单,果不其然,提示了以下错误:
“java.io.IOException: Cannot run program "/system/xbin/su": error=13, Permission denied
思考再三,觉得这是因为系统对应用层访问权限是管理很严格的,不允许直接获取su的root权限的。没办法,要想在应用层能够有权限访问,还是得系统源码能过够支持,需要在源码上修改才行。
后来在网上一顿查阅,也大概了解了破解之法。
解决方法:
应用层如果想顺利执行Linux命令,需要达到两个条件:
-
修改系统启动参数, 加入"androidboot.selinux=permissive"这样的设置;
-
修改/system/xbin/su的权限;
第一个条件需要修改系统启动参数,可以根据一下链接进行参考修改:
这里主要讲一下第二种,修改su的权限:
如果系统中su权限是这样的: -rwsr-x--- root shell,则应用层APP无法获取root权限(即便是system权限的应用也不行),需要修改Android源码重新编译固件。
![](https://img-blog.csdnimg.cn/d339feaac50d4b1ba2db5edb4413ca27.png)
但如果系统中su权限是这样的: -rwsr-sr-x root shell,则通过上面代码方式可以直接获得root权限。
![](https://img-blog.csdnimg.cn/4e55369591d548dcb5aff0342f4b33de.png)
参考链接如下:
根据上述两个参考连接来修改了Android源码重新编译出来的Android系统固件,就能够满足权限的问题了,然后我们应用层APP就可以直接操作Linux命令和脚本了。
亲测有效,大家可以借鉴参考。