在过去的一周中,我一直在构建RMI应用程序,但遇到了一个障碍,似乎无法进行大量的谷歌搜索。
以下代码用于通过RMI将对象从服务器发送到客户端:
服务器代码:
import rocks.Rock;
import rocks.squareRock;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
public class Server extends UnicastRemoteObject
implements RemInterface {
public Server() throws RemoteException {
super();
}
public static void main(String argv[]) {
try {
Server serv = new Server();
Naming.rebind("RockServer", serv);
} catch (Throwable t) {
t.printStackTrace();
}
}
public Rock getRock() {
return new squareRock();
}
}
客户代码:
import rocks.Rock;
import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
public class Client {
RemInterface reminterface = null;
public Client() {
String strName = "rmi://127.0.0.1/RockServer";
try {
reminterface = (RemInterface) Naming.lookup(strName);
} catch (RemoteException e) {
e.printStackTrace();
} catch (NotBoundException e) {
e.printStackTrace();
} catch (MalformedURLException e) {
e.printStackTrace();
}
}
public Rock loadRock() {
try {
return reminterface.getRock();
} catch (Throwable t) {
return null;
}
}
}
接口:
public interface RemInterface {
public Rock getRock() throws RemoteException;
}
在这个情况下:
客户端和服务器类路径中都可以使用“ Rock”类。
“ Rock”类实现可序列化。
“ squareRock”扩展了类摇滚,仅在服务器的类路径中可用。
当尝试在客户端上使用来自loadRock()的Rock调用方法时,出现以下错误:
STDERR: java.rmi.UnmarshalException: error unmarshalling return; nested exception is:
java.lang.ClassNotFoundException: SquareRock
任何帮助,将不胜感激。
最佳答案
您正在从服务器返回类型rocks.squareRock
的对象。在客户端进行反序列化过程中,将需要使用此类,以便创建此类的实例来表示来自服务器的响应。正如您已经指出的那样,该类仅在服务器的类路径中可用,找不到和加载所述类的失败会导致异常。
解决方案是使rocks.squareRock
类也可以在客户端中使用。