Prev Class | Next Class | Frames | No Frames |
Summary: Nested | Field | Method | Constr | Detail: Nested | Field | Method | Constr |
java.lang.Object
java.security.Policy
Policy
is an abstract class for managing the system security
policy for the Java application environment. It specifies which permissions
are available for code from various sources. The security policy is
represented through a subclass of Policy
.
Only one Policy
is in effect at any time. A
ProtectionDomain
initializes itself with information from this class
on the set of permssions to grant.
The location for the actual Policy
could be anywhere in any
form because it depends on the Policy implementation. The default system is
in a flat ASCII file or it could be in a database.
The current installed Policy
can be accessed with
getPolicy()
and changed with setPolicy(Policy)
if the code
has the correct permissions.
The refresh()
method causes the Policy
instance to
refresh/reload its configuration. The method used to refresh depends on the
Policy
implementation.
When a protection domain initializes its permissions, it uses code like
the following:
policy = Policy.getPolicy();
PermissionCollection perms = policy.getPermissions(myCodeSource);
The protection domain passes the Policy
handler a
CodeSource
instance which contains the codebase URL and a public key.
The Policy
implementation then returns the proper set of
permissions for that CodeSource
.
The default Policy
implementation can be changed by setting
the "policy.provider" security provider in the "java.security" file to the
correct Policy
implementation class.
CodeSource
, PermissionCollection
, SecureClassLoader
Constructor Summary | |
|
Method Summary | |
abstract PermissionCollection |
|
PermissionCollection |
|
static Policy |
|
boolean |
|
abstract void |
|
static void |
Methods inherited from class java.lang.Object | |
clone , equals , extends Object> getClass , finalize , hashCode , notify , notifyAll , toString , wait , wait , wait |
public abstract PermissionCollection getPermissions(CodeSource codesource)
Returns the set of Permissions allowed for a givenCodeSource
.
- Parameters:
codesource
- theCodeSource
for which, the caller needs to find the set of granted permissions.
- Returns:
- a set of permissions for
CodeSource
specified by the currentPolicy
.
- Throws:
SecurityException
- if aSecurityManager
is installed which disallows this operation.
public PermissionCollection getPermissions(ProtectionDomain domain)
Returns the set of Permissions allowed for a givenProtectionDomain
.
- Parameters:
domain
- theProtectionDomain
for which, the caller needs to find the set of granted permissions.
- Returns:
- a set of permissions for
ProtectionDomain
specified by the currentPolicy.
.
- Since:
- 1.4
- See Also:
ProtectionDomain
,SecureClassLoader
public static Policy getPolicy()
Returns the currently installedPolicy
handler. The value should not be cached as it can be changed any time bysetPolicy(Policy)
.
- Returns:
- the current
Policy
.
- Throws:
SecurityException
- if aSecurityManager
is installed which disallows this operation.
public boolean implies(ProtectionDomain domain, Permission permission)
Checks if the designatedPermission
is granted to a designatedProtectionDomain
.
- Parameters:
domain
- theProtectionDomain
to test.permission
- thePermission
to check.
- Returns:
true
ifpermission
is implied by a permission granted to thisProtectionDomain
. Returnsfalse
otherwise.
- Since:
- 1.4
- See Also:
ProtectionDomain
public abstract void refresh()
Causes thisPolicy
instance to refresh / reload its configuration. The method used to refresh depends on the concrete implementation.
public static void setPolicy(Policy policy)
Sets thePolicy
handler to a new value.
- Parameters:
policy
- the newPolicy
to use.
- Throws:
SecurityException
- if aSecurityManager
is installed which disallows this operation.