Android执行shell脚本

本文探讨了在Android应用中通过Java程序和C/C++程序执行Shell脚本的方法,以及如何在Android系统中启动服务执行脚本。重点介绍了服务的编写、权限检查以及在应用中启动服务的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、如果是java程序执行shell脚本,那么在适当的地方加入下面的这段代码:(其中PATH是脚本所在目录,shellname.sh是所要执行的脚本名字)

  1.         try {
  2.                 execCommand(". PATH/shellname.sh");   
  3.                 } catch (IOException e) {
  4.                         // TODO Auto-generated catch block
  5.                         e.printStackTrace();
  6.                
  7.    
  8.    
  9. execCommand方法的实现如下:
  1.     public void execCommand(String command) throws IOException {

  2.         Runtime runtime = Runtime.getRuntime();  
  3.         Process proc = runtime.exec(command);        //这句话就是shell与高级语言间的调用

  4.         //使用exec执行不会等执行成功以后才返回,它会立即返回
  5.         //所以在某些情况下是很要命的(比如复制文件的时候)
  6.         //使用wairFor()可以等待命令执行完成以后才返回
  7.         try {
  8.             if (proc.waitFor() != 0) {
  9.                 System.err.println("exit value = " + proc.exitValue());
  10.             
  11.         }
  12.         catch (InterruptedException e) {  
  13.             System.err.println(e);
  14.         }
  15.     }


2、如果是在C或者C++程序中执行shell脚本的话,就比较简单:system(". PATH/shellname.sh");  即可
 
 

如何让Android系统或Android应用执行shell脚本

一、Android应用启动服务执行脚本

1 如何写服务和脚本

android源码根目录下有/device/tegatech/tegav2/init.rc文件相信大家对这个文件都不陌生(如果不明白就仔细研读下android启动流程)。如果在该脚本文件中添加诸如以下服务:

service usblp_test  /data/setip/init.usblpmod.sh   

oneshot

   disabled

注解:每个设备下都会有自己对应的init.rcinit.设备名.rc脚本文件。oneshot disabled向我们说明了在系统启动的时候这个服务是不会自动启动的。并且该服务的目的是执行/data/setip/init.usblpmod.sh脚本。脚本的内容你可以随便写,只要符合shell语法就可以了,比如脚本可以是简单的设置eth0:

# ! /system/bin/sh //脚本的开头必须这样写。

Ifconfig eth0 172.16.100.206 netmask 255.255.0.0 up//设置ip的命令

2、如何在应用中启动服务

1)首先了解下在服务启动的流程

system/core/init/init.rcMain函数的for(;;)循环中一个

1.     在你的应用中让init.rc中添加的服务启动起来。

首先了解下在服务启动的流程:

           在设备目录下的init.c(切记并不是system/core/init/init.rc

Main函数的for(;;)循环中有一个handle_property_set_fd(),函数,这个函数的实现也在system/core/init目录下,该函数中的check_control_perms(msg.value, cr.uid, cr.gid)函数就是检查该uid是否有权限启动服务(msg.value就是你服务的名字),如果应用为rootsystem用户则直接返回1.之后就是调用handle_control_message((char*) msg.name + 4, (char*) msg.value)

该函数的参数就是去掉1.ctl.后的start2.你服务的名字。

这个函数的详细内容:

 匹配start后调用msg_start.

 

看到service_start后相信你已经很明白了。

 

我们的解决方案就是在检查权限的地方“下点功夫”

在该函数体内,for循环之上加上如下代码,只要匹配到是我们自己的服务就让它启动。

If(strcmp(“usblp_test”,name)==0)

Return 1;

这样做不会破坏android原本的结构,不会有什么副作用。

 

之后在应用程序中调用:do_exec(start usblp_test);

二、编译源码执行shell脚本

这个方法很简单,脚本已经写好了,现在要解决的问题是在什么时候怎么执行这个脚本,经过验证最佳的位置在system/core/init/init.c,main函数中的如下位置,

  queue_builtin_action(queue_property_triggers_action, "queue_propety_triggers");

#if BOOTCHART

    queue_builtin_action(bootchart_init_action, "bootchart_init");

#endif

    /*add by weijing */

    system("exec /system/bin/sh /data/setip/init.djstava.sh");

   /*end by weijing */

    for(;;) {

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值