在过去的一周中,我一直在构建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类也可以在客户端中使用。

10-04 13:59