Setting the security access to AllPermission is easy and removes all possible security issues that may hinder development of a Jini application. However, it leaves your system open , so you must start using a more rigorous security policy at some stage ”hopefully before others have damaged your system. The problem with moving away from this open policy is that permissions are additive rather than subtractive . That is, you can't take permissions away from AllPermission; you have to start with an empty permission set and add to that.
Not giving enough permission can result in at least three situations when you try to access something:
The first two cases will occur if permissions are turned off for the service providers, such as in the rmi.FileClassifierServer of Chapter 8 if insufficient permissions are given.
There is a java.security.debug system property that can be set to print information about various types of access to the security mechanisms. This can be used with a slack security policy to find out exactly what permissions are being granted. Then, with the screws tightened, you can see where permission is being denied. An appropriate value for this property is access , as in
java -Djava.security.debug=access ...
For example, running client.TestFileClassifier with few permissions granted may result in a trace such as the following:
... access: access allowed (java.util.PropertyPermission socksProxyHost read) access: access allowed (java.net.SocketPermission 127.0.0.1:1174 accept,resolve) access: access denied (java.net.SocketPermission 184.108.40.206:1024 accept,resolve) access: access denied (java.net.SocketPermission 220.127.116.11:1025 accept,resolve) access: access denied (java.net.SocketPermission 18.104.22.168:1027 accept,resolve) ...
The denied access is an attempt to make a socket accept or resolve request on my laptop (IP address 22.214.171.124), probably for RMI-related sockets. Since the client just sits there indefinitely making this request on one random port after another, this permission needs to be opened up, because the client otherwise appears to just hang.