The name is the name of the property ("java.home", "os.name", etc). The naming convention follows the hierarchical property naming convention. Also, an asterisk may appear at the end of the name, following a ".", or by itself, to signify a wildcard match. For example: "java.*" or "*" is valid, "*java" or "a*b" is not valid.
The actions to be granted are passed to the constructor in a string containing a list of zero or more comma-separated keywords. The possible keywords are "read" and "write". Their meaning is defined as follows:
System.getProperty to
be called.
System.setProperty to
be called.
The actions string is converted to lowercase before processing.
Care should be taken before granting code permission to access certain system properties. For example, granting permission to access the "java.home" system property gives potentially malevolent code sensitive information about the system environment (the Java installation directory). Also, granting permission to access the "user.name" and "user.home" system properties gives potentially malevolent code sensitive information about the user environment (the user's account name and home directory).
| Constructor Summary | ||
| PropertyPermission(String name, String actions) Creates a new PropertyPermission object with the specified name. |
| Method Summary | ||
boolean |
equals(Object obj) Checks two PropertyPermission objects for equality. |
|
| getActions() Returns the "canonical string representation" of the actions. |
||
int |
hashCode() Returns the hash code value for this object. |
|
boolean |
implies(java.security.Permission p) Checks if this PropertyPermission object "implies" the specified
permission. |
|
| newPermissionCollection() Returns a new PermissionCollection object for storing
PropertyPermission objects. |
||
| Methods inherited from class java.security.Permission |
| checkGuard, getName, toString |
| Methods inherited from class java.lang.Object |
| clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
More specifically, this method returns true if:
getName().hashCode(), where getName is
from the Permission superclass.getActions
will return the string "read,write".