code review request: 7051946: Runtime.exec(String command) / ProcessBuilder command parsing issues
Alan Bateman
Alan.Bateman at oracle.com
Thu Sep 15 10:00:43 UTC 2011
Alan Bateman wrote:
> Michael McMahon wrote:
>> We could add a sentence to the existing @throws clause for IAE.
>>
>> So it would say "If |command| is empty, or on some platforms, may be
>> thrown if command contains illegal characters".
>>
>> I'm reluctant to be more precise than that, since as far as I know,
>> there doesn't appear to be
>> any illegal characters for filenames in Unix.
> I agree that you can't be too specific. I'm not sure if "illegal
> characters" should be in the wording as it begs the question as to
> which characters are legal. An alternative to trying to come up with
> some wording is to just specify the long standing behavior which seems
> to be that IOException is thrown if an I/O errors or the command line
> is malformed. I see David's reply pointing out that there are similar
> issues with ProcessBuilder. That is only specified to throw
> IndexOutOfBoundException if the command line is empty so it would be
> good to check those cases too.
>
> -Alan.
I went through the rest of the changes.
In src/solaris/classes/java/lang/ProcessImpl.java then the permission
check needs to happen before the streams are redirected as otherwise it
would allow an attacker to truncate arbitrary files. I think the
alignment is a bit out at L132-142.
In src/windows/classes/java/lang/ProcessImpl.java L211-216 is using
toLowerCase (which is locale specific) and is assuming that prog and
lprog will be the same length.
The algorithm in getProgramPath seems okay although I think it can be
cleaned up a bit (coding style is inconsistent with the rest of the file
for example, is the StringBuilder actually needed). Minor comment is
that "fileHasNoDot" is an odd method name, maybe hasDot would be nicer.
There's space between File and "(" at line 323.
A general comment is that what would it take to move this code away from
using StringTokenizer? I realize Runtime.exec has javadoc to say that it
uses StringTokenizer and I just wonder if that can be re-visited.
-Alan.
More information about the core-libs-dev
mailing list