次の Windows バッチ ファイル (run.bat) があります。
@echo off
echo hello batch file to sysout
次の Java コードは、バッチ ファイルを実行し、出力をファイルにリダイレクトします。
public static void main(String[] args) throws IOException {
System.out.println("Current java version is: " + System.getProperty("java.version"));
ProcessBuilder pb =
new ProcessBuilder("cmd.exe", "/c",
"run.bat"
,">>", "stdout.txt","2>>", "stderr.txt"
);
System.out.println("Command is: " + pb.command());
Process proc = pb.start();
InputStream in = proc.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
String line = null;
while ((line = reader.readLine()) != null) {
System.out.println(line);
}
int exitValue = proc.exitValue();
System.out.println("Exit value: " + exitValue);
}
JDK6u43 までの JDK では、次の出力が得られます。
Current java version is: 1.6.0_29
Command is: [cmd.exe, /c, run.bat, >>, stdout.txt, 2>>, stderr.txt]
Exit value: 0
スクリプト出力がファイルに書き込まれます。JDK 6u45 および 7 の時点で、次の出力が得られます。
Current java version is: 1.6.0_45
Command is: [cmd.exe, /c, run.bat, >>, stdout.txt, 2>>, stderr.txt]
hello batch file to sysout
Exit value: 0
出力ファイルには何も書き込まれません。
これは、 http://www.oracle.com/technetwork/java/javase/6u45-relnotes-1932876.htmlで説明されている Runtime.exec() で行われた変更に関連している場合と関連していない場合があります。
出力をファイルにリダイレクトして Windows でプロセスを開始する正しい方法は何ですか?
注: 実際のシナリオでは、実行するコマンドには、次のようにスペースを含むパラメーターが含まれる場合があります。
ProcessBuilder pb = new ProcessBuilder("cmd.exe", "/c",
"run.bat", "Some Input With Spaces",
">>", "stdout.txt","2>>", "stderr.txt");