问题背景
需要基于OK_3568开发板(Android 11)进行串口通信开发调试,使用Google自带的串口工具库。
发现问题:
- 原
Process su = Runtime.getRuntime().exec("/system/bin/su");
方法无效,报java.io.IOException: Cannot run program "/system/bin/su": error=2, No such file or directory
错误; - 使用
Process su = Runtime.getRuntime().exec("/system/xbin/su");
,报错java.io.IOException: Cannot run program "/system/xbin/su": error=13, Permission denied
。
临时解决方法的操作流程
- 使用
adb connect ip:port
指令连接上设备; - 使用
su
命令进入root权限; - 使用chmod命令打开对应串口权限
chmod 777 /dev/ttyS4
、chmod 777 /dev/ttyS5
(我这里打开的是这两个串口); -
Process su = Runtime.getRuntime().exec("/system/xbin/su");
在高版本上面已经不能直接获取到Root权限了,这是需要进行以下操作(这里临时解决方案是使用adb工具,临时修改系统的参数设置:):-
adb root
,查看是否进入到了root权限; adb shell setenforce 0
注意要先进行"adb root"操作,否则,执行"adb shell setenforce 0"操作的时候会报错:
setenforce: Couldn't set enforcing status to '0': Permission denied
。 -
永久解决方法
应用层如果想顺利执行Linux命令,需要达到两个条件:
- 修改系统启动参数, 加入
"androidboot.selinux=permissive"
这样的设置; - 修改/system/xbin/su的权限;
第一个条件需要修改系统启动参数,可以根据Android 10 Selinux进行参考修改。
这里主要讲一下第二种,修改su的权限:
如果系统中su权限是这样的: -rwsr-x--- root shell
,则应用层APP无法获取root权限(即便是system权限的应用也不行),需要修改Android源码重新编译固件。
![](https://img.haomeiwen.com/i625706/3ab2686f02d45288.png)
但如果系统中su权限是这样的: -rwsr-sr-x root shell
,则通过上面代码方式可以直接获得root权限。
![](https://img.haomeiwen.com/i625706/4af795ed37b78a02.png)
参考Android 源码修改,使第三方应用可以直接使用su命令
根据上述两个参考连接来修改了Android源码重新编译出来的Android系统固件,就能够满足权限的问题了,然后我们应用层APP就可以直接操作Linux命令和脚本了。
网友评论