Прежде всего я хотел бы сказать, что я прочитал все другие темы, касающиеся apache commons exec.У меня есть исполняемый файл на основе терминала.При запуске он запрашивает ввод данных из командной строки.Мне нужно запустить эту программу из моей Java-программы и передать в нее некоторые команды.Я использую Apache Commons Exec.Это то, что у меня есть:
CommandLine command = new CommandLine("myExec");
DefaultExecuteResultHandler resultHandler = new DefaultExecuteResultHandler();
DefaultExecutor executor = new DefaultExecutor();
ShutdownHookProcessDestroyer processDestroyer = new ShutdownHookProcessDestroyer();
TextareaOutputStream outputstream = new TextareaOutputStream(jTextArea1); //this redirects the output to a text area by extending and overriding outputstream. Works perfect.
PumpStreamHandler streamHandler = new PumpStreamHandler(outputstream, outputstream);
executor.setStreamHandler(streamHandler);
OutputStream out = new ByteArrayOutputStream();
executor.getStreamHandler().setProcessInputStream(out);
executor.setProcessDestroyer(processDestroyer);
executor.execute(command, resultHandler);
out.write("myFile.dat\n".getBytes());
Это не работает.Как только моя программа запускается, происходит сбой:
forrtl: severe (24): end-of-file during read, unit 5, file stdin
Я также попытался с pipedinputstream, как здесь -> Проблема с множественным вводом команды с использованием Apache Commons Exec и извлечением вывода :
CommandLine command = new CommandLine("myExec");
DefaultExecuteResultHandler resultHandler = new DefaultExecuteResultHandler();
DefaultExecutor executor = new DefaultExecutor();
ShutdownHookProcessDestroyer processDestroyer = new ShutdownHookProcessDestroyer();
TextareaOutputStream outputstream = new TextareaOutputStream(jTextArea1); //this redirects the output to a text area by extending and overriding outputstream. Works perfect.
PipedInputStream stdin = new PipedInputStream();
BufferedOutputStream processInput = new BufferedOutputStream(new PipedOutputStream(stdin));
PumpStreamHandler streamHandler = new PumpStreamHandler(outputstream, outputstream, stdin);
executor.setStreamHandler(streamHandler);
executor.setProcessDestroyer(processDestroyer);
executor.execute(command, resultHandler);
processInput.write("myFile.dat\n".getBytes());
processInput.flush();
С этим он зависает до первой подсказки!Как будто flush () не имеет никакого эффекта.Терминальная программа никогда ничего не получает.
Я также пытался использовать эту идею: Как передать строковый аргумент в исполняемый файл, запущенный с помощью Apache Commons Exec?
Если я напишувсе в ByteArrayInputStream до запуска exec, то он работает.Если я запускаю exec, а затем пытаюсь что-то написать, то снова получаю первую ошибку.
Любая помощь будет очень признательна.
Просто для полноты (я не писал это, яне помню откуда я взял это из интернета).Это для перенаправления вывода в jTextArea:
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import javax.swing.JTextArea;
import javax.swing.SwingUtilities;
class TextareaOutputStream extends OutputStream {
private final JTextArea area;
private final StringBuffer buf = new StringBuffer(128);
public TextareaOutputStream(final JTextArea area) throws IOException {
this.area = area;
}
@Override
public void write(int c) throws IOException {
// append character to buffer
buf.append((char) c);
// and newline appends to textarea
if (c == '\n' || c == ':') {
flush();
}
}
@Override
public void close() {
flush();
}
@Override
public void flush() {
SwingUtilities.invokeLater(new Runnable() {
String str = buf.toString();
@Override
public void run() {
area.append(str);
}
});
buf.setLength(0);
}
public void message(String msg) {
if (buf.charAt(buf.length() - 1) != '\n') {
buf.append('\n');
}
buf.append(msg);
buf.append('\n');
flush();
}
}