Как предоставить sudo пароль root из Java?

Я пытаюсь написать небольшое приложение Java, которое перезапишет мой файл /etc/resolv.conf (у меня Ubuntu 12.04). Для этого мне нужно указать мой root пароль:

myUser@myMachine:~$ sudo vim /etc/resolv.conf 
[sudo] password for myUser: *****

Таким образом, процесс для этого состоит из трех шагов:

  1. Введите sudo vim /etc/resolv.conf в терминале
  2. Терминал просит меня ввести мой root пароль
  3. Ввожу пароль и нажимаю [Enter]

Из всего, что я исследовал, я мог бы использовать следующее для выполнения шага № 1 выше:

try {
    String installTrickledCmd = "sudo vim /etc/resolv.conf";
    Runtime runtime = Runtime.getRuntime();
    Process proc = runtime.exec(installTrickledCmd);
}
catch(Throwable throwable) {
    throw new RuntimeException(throwable);
}

Но когда это выполняется, оболочка захочет запросить у моего процесса Java пароль. Я не знаю, как дождаться этого (шаг № 2 выше), а затем передать мой пароль обратно в оболочку (шаг № 3 выше). Заранее спасибо.


person IAmYourFaja    schedule 24.12.2012    source источник
comment
Я думаю, что это решение должно работать: stackoverflow.com /questions/233217/password-to-su-sudo-ssh   -  person Philip Whitehouse    schedule 24.12.2012
comment
Вместо echo ввода пароля вы также можете использовать Process.getOutputStream(), а затем запишите пароль на этот поток.   -  person JimmyB    schedule 24.12.2012


Ответы (2)


Вы пробовали с -S ?

$echo mypassword | sudo -S vim /etc/resolv.conf

От человека:

The -S (stdin) option causes sudo to read the password from the standard input 
instead of the terminal device.  The password must be followed by a newline 
character.
person Luigi R. Viggiano    schedule 24.12.2012

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;

public class Test1 {

  public static void main(String[] args) throws Exception {
    String[] cmd = {"sudo","-S", "ls"};
    System.out.println(runSudoCommand(cmd));
  }

  private static int runSudoCommand(String[] command) throws Exception {

    Runtime runtime =Runtime.getRuntime();
    Process process = runtime.exec(command);
    OutputStream os = process.getOutputStream();
    os.write("harekrishna\n".getBytes());
    os.flush();
    os.close();
    process.waitFor();
    String output = readFile(process.getInputStream());
    if (output != null && !output.isEmpty()) {
      System.out.println(output);
    }
    String error = readFile(process.getErrorStream());
    if (error != null && !error.isEmpty()) {
      System.out.println(error);
    }
    return process.exitValue();
  }

  private static String readFile(InputStream inputStream) throws Exception {
    if (inputStream == null) {
      return "";
    }
    StringBuilder sb = new StringBuilder();
    BufferedReader bufferedReader = null;
    try {
      bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
      String line = bufferedReader.readLine();
      while (line != null) {
        sb.append(line);
        line = bufferedReader.readLine();
      }
      return sb.toString();
    } finally {
      if (bufferedReader != null) {
        bufferedReader.close();
      }
    }
  }

}

Вдохновленный ответом Виджано.

person Ashish Doneriya    schedule 26.05.2017
comment
Я знаю, что это устарело и это был всего лишь образец, но я хотел предупредить, что помещать пароли в строки — плохая практика. Это приводит к тому, что пароль сохраняется в памяти на неопределенный срок. В вашем случае, поскольку вы использовали литерал, он хранится в памяти на время жизни JVM. Вы должны хранить незашифрованные пароли в памяти как можно меньше времени, и вы должны хранить их как можно более эфемерно — обычно предпочтительнее использовать char[]. - person JakeRobb; 27.09.2018
comment
@JakeRobb, как кто-то мог найти пароль от JVM. - person Ashish Doneriya; 01.10.2018