Ответ 1
Вам нужно запустить новый поток, который будет считывать выходной поток терминала и копировать его на консоль после вызова process.waitFor()
Я пытаюсь получить OutputStream
Process
, инициированный exec()
, на консоль. Как это можно сделать?
Вот неполный код:
import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
import java.io.Reader;
public class RuntimeTests
{
public static void main(String[] args)
{
File path = new File("C:\\Dir\\Dir2");
String command = "cmd /c dir";
Reader rdr = null;
PrintStream prtStrm = System.out;
try
{
Runtime terminal = Runtime.getRuntime();
OutputStream rtm = terminal.exec(command, null, path).getOutputStream();
prtStrm = new PrintStream(rtm);
prtStrm.println();
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
Вам нужно запустить новый поток, который будет считывать выходной поток терминала и копировать его на консоль после вызова process.waitFor()
Недавно я столкнулся с этой проблемой и просто хотел упомянуть, что начиная с Java 7 был расширен компоновщик процессов API. Теперь эту проблему можно решить с помощью:
ProcessBuilder pb = new ProcessBuilder("yourcommand");
pb.redirectOutput(Redirect.INHERIT);
pb.redirectError(Redirect.INHERIT);
Process p = pb.start();
Я считаю, что это то, что вы ищете:
String line;
Process p = Runtime.getRuntime().exec(...);
BufferedReader input = new BufferedReader(new InputStreamReader(p.getInputStream()));
while ((line = input.readLine()) != null) {
System.out.println(line);
}
input.close();
У меня возникла аналогичная проблема, и я использую следующий код.
Process p = Runtime.getRuntime().exec(".....");
p.waitFor();
String line;
BufferedReader error = new BufferedReader(new InputStreamReader(p.getErrorStream()));
while((line = error.readLine()) != null){
System.out.println(line);
}
error.close();
BufferedReader input = new BufferedReader(new InputStreamReader(p.getInputStream()));
while((line=input.readLine()) != null){
System.out.println(line);
}
input.close();
OutputStream outputStream = p.getOutputStream();
PrintStream printStream = new PrintStream(outputStream);
printStream.println();
printStream.flush();
printStream.close();
Попробуйте VerboseProcess
из jcabi-log:
String output = new VerboseProcess(new ProcessBuilder("foo.bat")).stdout();
Класс запускает фоновый поток, прослушивает выходной поток и записывает его в журнал.
Если вы можете использовать org.apache.commons.io.IOUTils из commons-io,
System.out.println(IOUtils.toString(process.getInputStream()));
System.err.println(IOUtils.toString(process.getErrorStream()));
Я знаю, что это очень старый вопрос, но лучшей альтернативой для приведенных выше ответов будет
ProcessBuilder builder = new ProcessBuilder(command);
builder.inheritIO();
Process p = builder.start();
Из документов ProcessBuilder.inheritIO()
,
Устанавливает источник и назначение для стандартного ввода-вывода подпроцесса таким же, как и у текущего процесса Java.
Надеюсь, это поможет кому-то!