java - RMI 解码异常

标签 java classloader rmi

我目前正在开发一个通过 rmi 加载类的系统。该系统使用与服务器通信的类加载器来获取类。代码如下。

服务器:

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 Class<?> getRockClass(String type) {
        if (type.equals("squareRock"))
            return squareRock.class;
        else
            return null;
    }
}

客户:

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;
    RockLoader rl = null;

    public Client() {
        String strName = "rmi://127.0.0.1/RockServer";
        try {
            reminterface = (RemInterface) Naming.lookup(strName);
            rl = new RockLoader(reminterface);
        } catch (RemoteException e) {
            e.printStackTrace();
        } catch (NotBoundException e) {
            e.printStackTrace();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        }

        loadRock("squareRock");

    }

    public Rock loadRock(String rock) {
        try {
            return (Rock) rl.loadClass(rock, false).newInstance();
        } catch (Throwable t) {
            return null;
        }
    }
}

界面:

public interface RemInterface {
    public Class<?> getRockClass(String type) throws RemoteException;
}

岩石装载机:

import java.io.Serializable;

public class RockLoader extends ClassLoader implements Serializable {

    private RemInterface reminterface = null;

    public RockLoader(RemInterface reminterface) {
        super();
        this.reminterface = reminterface;
    }

    @Override
    protected synchronized Class<?> loadClass(String className, boolean resolve)
            throws ClassNotFoundException {
        try {
            return reminterface.getRockClass(className);
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
}

我遇到的错误是(客户端):

java.rmi.UnmarshalException: error unmarshalling return; nested exception is: 
java.lang.ClassNotFoundException: SquareRock

这让我很困惑,因为我不是解码 SquareRock 实例,而是解码一个类。我唯一的想法是我的类加载器可能是错误的。

最佳答案

它是类还是对象并不重要。接收 JVM 的类路径中必须包含该类,除非您使用 RMI 代码库功能。您所做的基本上是尝试自己实现代码库功能。你不能这样做。

关于java - RMI 解码异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6116646/

相关文章:

java - int[] 数组的outputStream.write()

java - 在xuggler中设置缩略图宽度和高度

java - 如何动态设置 String.format 中的移位?

java - 不同插件中单独的 DLL 和 native 调用

java - 访问 RMI 服务器

java - 如何使用经度和纬度获取地址

java - Maven 管理的依赖项与声明的具有不同名称的依赖项之间的冲突

java - 在 Java 中,Class.forName 可以返回 null 吗?

java rmi 调用在抛出远程异常后被丢弃

java - RMI 服务器接口(interface)(调度程序)方法抛出 java.lang.NoClassDefFoundError