Rozważ następujący kod:
String commandf = "ls /etc | grep release";
try {
// Execute the command and wait for it to complete
Process child = Runtime.getRuntime().exec(commandf);
child.waitFor();
// Print the first 16 bytes of its output
InputStream i = child.getInputStream();
byte[] b = new byte[16];
i.read(b, 0, b.length);
System.out.println(new String(b));
} catch (IOException e) {
e.printStackTrace();
System.exit(-1);
}
Wynik programu to:
/etc:
adduser.co
Kiedy biegnę z powłoki, to oczywiście działa zgodnie z oczekiwaniami:
poundifdef@parker:~/rabbit_test$ ls /etc | grep release
lsb-release
Internety mówią mi, że ze względu na fakt, że zachowanie potoków nie jest wieloplatformowe, genialne umysły pracujące w fabryce Javy produkującej Javę nie mogą zagwarantować, że potoki będą działać.
W jaki sposób mogę to zrobić?
Nie zamierzam wykonywać całego analizowania przy użyciu konstrukcji Java zamiast grep
ised
, bo jeśli chcę zmienić język, będę zmuszony do ponownego napisać kod parsowania w tym języku, który jest całkowicie nie-Go.
Jak sprawić, by Java wykonywała potoki i przekierowywanie podczas wywoływania poleceń powłoki?
command | grep foo
ty, znacznie lepiej jest po prostu uruchomić command
i wykonać filtrowanie natywnie w Javie. To sprawia, że twój kod jest nieco bardziej złożony, ale także znacznie zmniejszasz ogólne zużycie zasobów i powierzchnię ataku.