私が知る限り、コマンドラインコマンドはroot権限でのみ実行できます。あなたがする必要があるのは、このクラスを拡張し、rootとして実行するコマンドを返すようにgetCommandsToExecute
メソッドをオーバーライドしている http://muzikant-android.blogspot.com/2011/02/how-to-get-root-access-and-execute.html
:あなたはあなたのコードのルートアクセスをラップ私が作ったこのジェネリッククラスを使用することができます。
public abstract class ExecuteAsRootBase
{
public static boolean canRunRootCommands()
{
boolean retval = false;
Process suProcess;
try
{
suProcess = Runtime.getRuntime().exec("su");
DataOutputStream os = new DataOutputStream(suProcess.getOutputStream());
DataInputStream osRes = new DataInputStream(suProcess.getInputStream());
if (null != os && null != osRes)
{
// Getting the id of the current user to check if this is root
os.writeBytes("id\n");
os.flush();
String currUid = osRes.readLine();
boolean exitSu = false;
if (null == currUid)
{
retval = false;
exitSu = false;
Log.d("ROOT", "Can't get root access or denied by user");
}
else if (true == currUid.contains("uid=0"))
{
retval = true;
exitSu = true;
Log.d("ROOT", "Root access granted");
}
else
{
retval = false;
exitSu = true;
Log.d("ROOT", "Root access rejected: " + currUid);
}
if (exitSu)
{
os.writeBytes("exit\n");
os.flush();
}
}
}
catch (Exception e)
{
// Can't get root !
// Probably broken pipe exception on trying to write to output stream (os) after su failed, meaning that the device is not rooted
retval = false;
Log.d("ROOT", "Root access rejected [" + e.getClass().getName() + "] : " + e.getMessage());
}
return retval;
}
public final boolean execute()
{
boolean retval = false;
try
{
ArrayList<String> commands = getCommandsToExecute();
if (null != commands && commands.size() > 0)
{
Process suProcess = Runtime.getRuntime().exec("su");
DataOutputStream os = new DataOutputStream(suProcess.getOutputStream());
// Execute commands that require root access
for (String currCommand : commands)
{
os.writeBytes(currCommand + "\n");
os.flush();
}
os.writeBytes("exit\n");
os.flush();
try
{
int suProcessRetval = suProcess.waitFor();
if (255 != suProcessRetval)
{
// Root access granted
retval = true;
}
else
{
// Root access denied
retval = false;
}
}
catch (Exception ex)
{
Log.e("ROOT", "Error executing root action", ex);
}
}
}
catch (IOException ex)
{
Log.w("ROOT", "Can't get root access", ex);
}
catch (SecurityException ex)
{
Log.w("ROOT", "Can't get root access", ex);
}
catch (Exception ex)
{
Log.w("ROOT", "Error executing internal operation", ex);
}
return retval;
}
protected abstract ArrayList<String> getCommandsToExecute();
}
既存のプロセスの特権を昇格する手段は実際にはありません。新しいプロセスをルートとして実行することを意味します。 suコマンドに実行コマンドが渡された例については、http://stackoverflow.com/questions/4846241/more-than-one-superuser-command-android/4846312 –
を参照してください。@Chris新しいアクティビティ/タスク/ AndroidのJavaアプリ/ etc? –
それはアンドロイドに巨大な変更を必要とするでしょう。あなたは通常アンドロイドのJava実行のためのプロセスを作成するのではなく、アンドロイドに 'zygote'にそのアプリケーションのユーザーIDの下でフォークするように依頼します。ルート・タスクをネイティブの実行可能ファイルまたはシェル・スクリプトとしてアプリケーションに代わって重要な作業を行うように保つ方が簡単です。または、特権システムサービスとして適切なシステムに追加します。多くの場合、最良の方法は、UNIXグループを作成して特定の機能(デバイスファイルへのアクセスなど)にアクセスさせ、そのグループでサービスを実行するか、アンドロイドの許可を得てペアにすることです。 –