RMI UnmarshalException - PullRequest
       15

RMI UnmarshalException

1 голос
/ 25 мая 2011

В настоящее время я разрабатываю систему, которая загружает классы через 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;
}

RockLoader:

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, а класс. Я думал только о том, что мой загрузчик классов может ошибаться.

1 Ответ

1 голос
/ 25 мая 2011

Неважно, класс это или объект.Принимающая JVM должна иметь этот класс в своем classpath, если вы не используете функцию кодовой базы RMI.То, что вы делаете, в основном пытается реализовать функцию кодовой базы самостоятельно.Вы не можете этого сделать.

...