Code Review Request for 6578042
Alan Bateman
Alan.Bateman at oracle.com
Sun Nov 6 10:45:14 UTC 2011
On 02/11/2011 19:59, David Holmes wrote:
>
> I'm not seeing a distinction in those two statements. Both expect to
> return the property value for a given key; both assume a valid value
> is a String. clearProperty throws ClassCastException if the assumption
> doesn't hold; getProperty instead returns null.
The distinction is "value" vs. "string value", where the latter is
interpreted by Darryl's patch to be the String representation. While
that avoids the CCE, it is clearly inconsistent with System.getProperty
that I see is also specified to return the "string value". So I think we
have to dismiss this approach. I think this leaves two options:
1. Document existing behavior, meaning @throws CCE (several of
Properties methods already have this).
2. Change the method so that it is consistent with getProperty and so
returns null if the property value is not a String.
While option 2 is clearly a change then I think it's worth exploring to
understand the impact. Properties has always had a note in its javadoc
to warn users that it inherits from Hashtable and it has a note to
"strongly discourage" inserting entries that have a key or value that is
not a String. My guess (and this is purely a guess) is that
System.clearProperty is not used very often and so the likelihood of
someone abusing the system properties and using clearProperty is
probably low. I see the bug on bugs.sun.com doesn't have any votes or
comments which suggests that this one doesn't have an angry mob either.
Darryl - since you have decided to tackle this one then I would suggest
looking into this further and coming back with a recommendation. I would
also suggest that as part of the patch that the javadoc for
System.getProperty and Properties.getProperty be clarified so that it's
clear that they return null when the properties have been compromised.
-Alan.
More information about the core-libs-dev
mailing list