我正在为Netbeans中的课程作业创建RMI程序。这是一个简单的RMI程序,服务器端正常工作。但是当我运行我的客户端文件时。它最终给我错误
Exception in thread "main" java.security.AccessControlException: access denied ("java.net.SocketPermission" "127.0.0.1:1099" "connect,resolve")
加上它在客户端代码的第26行说了一些错误。 为了清楚了解,我提供了所有三个文件的完整代码。
Interface.java:
package RMI;
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface DemoInterface extends Remote {
public String SayDemo() throws RemoteException;
}
Server.java
package RMI;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.rmi.server.UnicastRemoteObject;
public class Server implements Interface{
public Server()
{
super();
}
private String message;
public Server(String msg) throws RemoteException
{
message = msg;
}
public static void main(String[] args) {
try {
DemoInterface h = new Server("Hello");
DemoInterface stub = (DemoInterface) UnicastRemoteObject.exportObject(h,0);
LocateRegistry.createRegistry(4096);
Registry registry = LocateRegistry.getRegistry("127.0.0.1",4096);
registry.rebind("Hello", stub);
System.out.println("Server is connected and ready to use");
}
catch(Exception e)
{
System.out.println("server not connected\n"+e);
}
}
@Override
public String SayDemo() throws RemoteException {
System.out.println("Server.saydemo override");
return message;
}
}
Client.java
package RMI;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
public class Client {
public static void main(String[] args) {
if(System.getSecurityManager() == null)
{
System.setSecurityManager(new SecurityManager());
}
try {
Registry reg = LocateRegistry.getRegistry("127.0.0.1", 4096);
System.out.println("in try after reg locate");
DemoInterface h = (DemoInterface) reg.lookup("Hello");//Error Showed on this line by netbeans
System.out.println(h.SayDemo());
}
catch(RemoteException | NotBoundException e)
{
System.out.println(""+e );
}
}
}
请指导我错在哪里。提前谢谢。
答案 0 :(得分:3)
您在客户端SecurityManager
方法中设置了main
。您是否也提供了安全策略文件?默认策略不是非常宽松的,并且否认了Socket操作等。
您可以指定一个策略,允许所有代码库的所有权限,如此。
grant {
permission java.security.AllPermission;
};
将其添加到命令行以调用java
。将mypolicy
替换为您的策略文件,将SomeApp
替换为您的主要类。 注意第二个参数中的两个=
字符
java -Djava.security.manager -Djava.security.policy==mypolicy SomeApp
请注意,这不是在生产环境中为RMI运行的安全策略(RMI可以加载远程代码库)。
正确使用SecurityManager
类和策略配置是一个复杂的主题,为了进一步阅读,我建议Java SE 7 Security Documentation,特别是Default Policy Implementation and Policy File Syntax