【App】app里执行shell命令的一个问题与方法

老化测试app里面可能要去写文件,如果是adb shell里面那就很简单,
直接
    echo 255 > /sys/class/leds/aw9106_led/brightness 

就可以点亮灯等操作,但是再app里面执行shell命令就有很多权限问题,比如sys的权限是root:root访问,也可能是666的权限,
这些都要去再rc文件里改系统源码。
   
    另外,网上的下面这种,先执行su或者system/xbin/su,也是有avc权限问题的,如下log:

 su: type=1400 audit(0.0:865): avc: denied { getattr } for path="/system/xbin/su" dev="mmcblk0p25" 
ino=3263 scontext=u:r:system_app:s0 tcontext=u:object_r:su_exec:s0 tclass=file permissive=1
    这又要去放开su的selinux权限,这样应该不妥吧

//	public void execShell(String cmd){
//        try{
//            Process p = Runtime.getRuntime().exec("su");
//            OutputStream outputStream = p.getOutputStream();
//            DataOutputStream dataOutputStream=new DataOutputStream(outputStream);
//            dataOutputStream.writeBytes(cmd);
//            dataOutputStream.flush();
//            dataOutputStream.close();
//            outputStream.close();
//       }
//       catch(Throwable t){
//             t.printStackTrace();
//       }
//	}
	
//		execShell("echo 255 >/sys/class/leds/aw9106_led/brightness");
//		execShell("echo 255 >/sys/class/leds/aw9106_led/brightness");
//		execShell("echo 255 >/sys/class/leds/aw9106_led/brightness");

---------
后面还是觉得写成c文件,ndk编译成可执行文件,然后推到/system/bin/或者在系统源码里面编译到system/bin/下比较简单,
system/bin下的可执行文件就免除root权限了==,有selinux权限也相对来说好加一些~~

------------------------------------------------------------------------------------
#define LOGD(...)   __android_log_print(ANDROID_LOG_DEBUG, "itv_assistance_native", __VA_ARGS__)

int main(int argC, char **argV)
{
    int value;
    if (argC != 2) {
          LOGD("argC is not right..\n");
         return 0;
    }
    value=atoi(argV[1]);
    if (value==1){
          LOGD("led on..\n");
        system("echo 255 >/sys/class/leds/aw9106_led/brightness");
     }
     else if (value==0){
         system("echo 0 >/sys/class/leds/aw9106_led/brightness");
         LOGD("led off..\n");
    }

    return 0;
}
--------------------------------------------------------------------------------

app调用就比较方便:
    Runtime.getRuntime().exec("ledtest 1");

----
后面想起来,之前想在app里执行"adb shell input tap X Y"模拟点击事件,也没有成功,现在也可以写在c里面,
把x,y坐标通过argv传进去。
    没有成功的原因是,输入事件的权限问题,在也要改系统源码或者app成跳权限过去,比较麻烦网上相关答案也比较少,后面没有弄了





 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Android应用中执行Shell命令可以通过`Runtime.getRuntime().exec(command)`方法来实现,其中`command`是要执行Shell命令字符串,比如`am start -n com.example.app/.MainActivity`。 要实现从一个Android应用中跳转到另一个应用,可以通过调用Shell命令执行`am start`命令。`am start`命令用于启动一个指定应用的特定Activity。 首先,需要确保设备已经root或者应用拥有相应的系统权限,才能执行Shell命令。然后,在应用中通过`Runtime.getRuntime().exec()`方法执行Shell命令。 下面是一个示例代码: ```java try { // 构建要执行命令 String packageName = "com.example.app"; String activityName = "com.example.app.MainActivity"; String command = "am start -n " + packageName + "/" + activityName; // 执行Shell命令 Process process = Runtime.getRuntime().exec(command); // 读取命令结果 BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream())); String line; while ((line = reader.readLine()) != null) { Log.d("Shell", line); } // 等待命令执行完成 process.waitFor(); } catch (IOException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } ``` 上述代码中,将要跳转的应用的包名和Activity名拼接成一个命令字符串,然后通过`Runtime.getRuntime().exec()`方法执行Shell命令。读取命令结果可以通过`InputStreamReader`和`BufferedReader`来实现,可以根据需要处理命令输出的结果。最后使用`process.waitFor()`等待命令执行完成。 需要注意的是,执行Shell命令需要小心处理,确保没有安全隐患。同时,要避免滥用Shell命令,以免影响到设备的正常运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值