转自:

Android应用程序如何调用shell脚本(一)

一般来说, Android 下的应用程序可以“直接”得到的最大的权限为 system ,但是如果我们需要在程序中执行某些需要 root 权限的命令,就需要 root 权限了。按照 Simon 的文章中提到的,应用程序有以下两种办法临时获得 root 权限:

1)         init.rc 实现一个 Service ,来帮助 Android 应用程序执行 root 权限的命令。

2)        实现一个虚拟设备,这个设备帮助 Android 应用程序执行 root 权限的命令。

第二种办法我这里没有尝试过。只介绍第一种方法。

1.       编写shell脚本或者可执行程序

下面是我的脚本cp_file.sh:

#! /system/bin/sh

cat /mnt/sdcard/launcher.db > /data/data/com.android.launcher/databases/launcher.db

chown system.system /data/ data/com.android.launcher/databases/launcher.db

chmod 600 /data/ data/com.android.launcher/databases/launcher.db

注意: 脚本的第一行必须为 # ! /system/bin/sh ,否则无法执行。

2.       在init.rc中注册service

service file_cp  /system/bin/cp_file.sh

user root

oneshot

disabled

其中, oneshot 表示程序退出后不再重新启动, disabled 表示不在系统启动时启动。

Service中参数的含义参见其它文章。

3.       将应用程序的权限提升至system

1.在应用程序的AndroidManifest.xml中的manifest节点中加入android:sharedUserId="android.uid.system"这个属性。

2.使用mm命令来编译该应用程序,生成的apk就具有system权限了。

4.       在应用程序中添加属性设置代码:

A. 在应用程序中使用getruntime().exec()函数来执行shell脚本文件。参考代码如下:

package cycle.settings.system;

import java.io.BufferedReader;

import java.io.DataOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import android.util.Log;

public class RuntimeExec {

private static final String TAG = "RuntimeExec";

private static final boolean DEBUG = true;//TODO: close this flag

private Process proc;

private StreamGobbler outputGobbler = null;

private StreamGobbler errorGobbler = null;

static class StreamGobbler extends Thread{

InputStream is;

String type; //输出流的类型ERROR或OUTPUT

public StreamGobbler(InputStream is, String type) {

// TODO Auto-generated constructor stub

this.is = is;

this.type = type;

}

public void run(){

try {

if(DEBUG)Log.d(TAG, "StreamGobbler start");

InputStreamReader isr = new InputStreamReader(is);

BufferedReader br = new BufferedReader(isr);

String line = null;

while((line = br.readLine()) != null){

System.out.println(type+">"+line);

System.out.flush();

}

if(DEBUG)Log.d(TAG, "StreamGobbler end");

} catch (IOException e) {

// TODO Auto-generated catch block

if(DEBUG)Log.d(TAG, "StreamGobbler exception");

e.printStackTrace();

}

}

}

/**

*

@param cmd : the command

@return success or failure

*/

public boolean runtimeExec(String cmd){

if(DEBUG)Log.d(TAG, "runtimeExec start");

boolean mboolean = false;

try {

if(DEBUG)Log.d(TAG, "runtimeExec start1");

Runtime mRuntime = Runtime.getRuntime();

proc = mRuntime.exec(cmd);

//any output message

StreamGobbler outputGobbler = new StreamGobbler(proc.getInputStream(),"OUTPUT");

//any error message

StreamGobbler errorGobbler = new StreamGobbler(proc.getErrorStream(), "ERROR");

//kick them off

outputGobbler.start();

//kick them off

errorGobbler.start();

int exitVal = proc.waitFor();

if(DEBUG)Log.d(TAG, "process exitValue: "+exitVal);

mboolean = (proc.waitFor()== 0);

} catch (Throwable e) {

// TODO Auto-generated catch block

if(DEBUG)Log.d(TAG, "process exception");

e.printStackTrace();

}

return mboolean;

}

public void runtimeEND(){

if(DEBUG)Log.d(TAG, "runtimeEND start");

try {

if(proc != null){

if(DEBUG)Log.d(TAG, "runtimeEND start1");

proc.getOutputStream().close();

if(DEBUG)Log.d(TAG, "close getOutputStream finish");

proc.getErrorStream().close();

if(DEBUG)Log.d(TAG, "close getErrorStream finish");

proc.destroy();

if(DEBUG)Log.d(TAG, "proc has destory");

}

else{

if(DEBUG)Log.e(TAG, "proc is null!!!!!");

}

if(DEBUG)Log.e(TAG, "before System.exit(0);");

System.exit(0);

if(DEBUG)Log.e(TAG, "after System.exit(0);");

proc = null;

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

未完,待续部分参考下篇博文。

参考博文:http://blog.csdn.net/silvervi/article/details/6315888

Android应用程序如何调用shell脚本(一)的更多相关文章

  1. C程序调用shell脚本共有三种方法

    C程序调用shell脚本共有三种法子 :system().popen().exec系列函数call_exec1.c ,内容为:system() 不用你自己去产生进程,它已经封装了,直接加入自己的命令e ...

  2. linux c程序中获取shell脚本输出的实现方法

    linux c程序中获取shell脚本输出的实现方法 1. 前言Unix界有一句名言:“一行shell脚本胜过万行C程序”,虽然这句话有些夸张,但不可否认的是,借助脚本确实能够极大的简化一些编程工作. ...

  3. linux C程序中获取shell脚本输出(如获取system命令输出)

    转载自 http://blog.csdn.net/hjxhjh/article/details/7909518 1. 前言 Unix 界有一句名言:“一行shell脚本胜过万行C程序”,虽然这句话有些 ...

  4. Python 调用 Shell脚本的方法

    Python 调用 Shell脚本的方法 1.os模块的popen方法 通过 os.popen() 返回的是 file read 的对象,对其进行读取 read() 的操作可以看到执行的输出. > ...

  5. Spring Boot 实现看门狗功能 (调用 Shell 脚本)

    需要实现看门狗功能,定时检测另外一个程序是否在运行,使用 crontab 仅可以实现检测程序是否正在运行,无法做到扩展,如:手动重启.程序升级(如果只需要实现自动升级功能可以使用 inotify)等功 ...

  6. 【原】Gradle调用shell脚本和python脚本并传参

    最近由于项目自动化构建的需要,研究了下gradle调用脚本并传参的用法,在此作个总结. Pre build.gradle中定义了$jenkinsJobName $jenkinsBuild两个Jenki ...

  7. 调用shell脚本,IP处理

    //调用shell脚本,IP处理 package com.letv.sdns.web.utils; import org.slf4j.Logger; import org.slf4j.LoggerFa ...

  8. Unity开发Android应用程序:调用安卓应用程序功能

    开发环境: Eclipse3.4 + adt12 + jdk6 + AndroidSDK2.2 Unity3.4 + windows7 测试设备: HTC Desire HD 本文要涉及到的几个重点问 ...

  9. Java 调用 shell 脚本详解

    这一年的项目中,有大量的场景需要Java 进程调用 Linux的bash shell 脚本实现相关功能. 从之前的项目中拷贝的相关模块和网上的例子来看,有个别的“陷阱”造成调用shell 脚本在某些特 ...

随机推荐

  1. POJ 1754 线段树

    e,应该是线段树里的水题.线段树单点更新.查询区间最值. 代码套用模板 PS :模板有些地方不太懂. #include<stdio.h>#include<iostream>#i ...

  2. Android如何打印std::cout/printf(重定向stdout)

    Android应用调试时没有stdout和stderr的输出,网上看到的解释都是下面这个样子: ################################################# An ...

  3. [转]VirtualBox中的网络连接方式详解

    如果出现主机无法ping通虚拟机的情况,请首先确认虚拟机防火墙已关闭. 一.NAT模式 特点: 1.如果主机可以上网,虚拟机可以上网 2.虚拟机之间不能ping通 3.虚拟机可以ping通主机(此时p ...

  4. selenium(五)伪造浏览器

    简介: 这个就比较好玩了,大家还记得以前的QQ小尾巴么?还有百度贴吧的小尾巴,就是那个来自***的iphone7,这个功能. 这个功能是基于浏览器的user-agent功能实现的. 还是httpbin ...

  5. 《Python》 property、classmethod、staticmethod、isinstance、issubclass

    一.property property是一个装饰器函数 装饰器函数的使用方法:在函数.方法.类的上面一行直接@装饰器的名字 装饰器的分类: 1.装饰函数 2.装饰方法:property 3.装饰类 i ...

  6. 关于RM中的X3014错误,以及mul() 、天空盒

    关于  error X3014: incorrect number of arguments to numeric-type constructor 这个错误应该是某个类似float4 这样的变量初始 ...

  7. Redis学习第七课:键值命令和服务器命令

    Redis键值相关命令                                                                                          ...

  8. Locust 其他协议

    Locust 是基于HTTP作为主要目标构建的,但是他同样可以扩展其他的协议,接受请求与获得返回.在编写的客户端的时候,我们就要使用到最常使用的 request_success 和 request_f ...

  9. centos 7 NAT模式网络设置

    打开虚拟机.菜单栏点击‘编辑’ -> ‘虚拟网络设置’. 注意下图红色框地方的设置: 然后进入linux系统,编辑网络配置: vi /etc/sysconfig/network-scripts/ ...

  10. HUD 1969:Pie(二分)

    Pie Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submis ...