rmi 调试出错 java.rmi.UnmarshalException: error unmarshalling arguments

fengyoujie 2008-11-06 11:44:03
我在网上下载一个学习rmi的例子程序,调试很长时间也没有没有调通,追后的错误如下:
Trobulett:java.rmi.ServerException: RemoteException occurred in server thread; nested exception is:
java.rmi.UnmarshalException: error unmarshalling arguments; nested exception is:
java.lang.ClassNotFoundException: CalculatorImpl_Stub
我在此对程序做个说明:
我将所有的文件保存在D:\rmiDemo这个目录下面总共有四个java文件:
1)接口 Calculator.java
import java.rmi.Remote;
public interface Calculator extends Remote{
public long add(long a,long b)throws java.rmi.RemoteException;
public long sub(long a,long b)throws java.rmi.RemoteException;
public long mul(long a,long b)throws java.rmi.RemoteException;
public long div(long a,long b)throws java.rmi.RemoteException;
}
2)接口的具体实现 CalculatorImpl.java

import java.rmi.server.UnicastRemoteObject;
public class CalculatorImpl extends UnicastRemoteObject implements Calculator{
//这个实现必须有一个显示的构造函数,并且要抛出一个RemoteException异常
public CalculatorImpl() throws java.rmi.RemoteException {
super();
}
public long add(long a,long b) throws java.rmi.RemoteException {
return a+b;
}
public long sub(long a,long b) throws java.rmi.RemoteException {
return a-b;
}
public long mul(long a,long b) throws java.rmi.RemoteException {
return a*b;
}
public long div(long a,long b) throws java.rmi.RemoteException {
return a/b;
}
}
3)客户端 CalculatorClient.java
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.net.MalformedURLException;
import java.rmi.NotBoundException;

public class CalculatorClient{
public static void main(String[] args){
try{
Calculator c = (Calculator)Naming.lookup("rmi://localhost/CalculatorService");
System.out.println(c.sub(4,3));
System.out.println(c.add(4,5));
System.out.println(c.mul(3,6));
System.out.println(c.div(9,3));
}catch (MalformedURLException murle) {
System.out.println();
System.out.println(
"MalformedURLException");
System.out.println(murle);
}
catch (RemoteException re) {
System.out.println();
System.out.println(
"RemoteException");
System.out.println(re);
}
catch (NotBoundException nbe) {
System.out.println();
System.out.println(
"NotBoundException");
System.out.println(nbe);
}
catch (
java.lang.ArithmeticException
ae) {
System.out.println();
System.out.println(
"java.lang.ArithmeticException");
System.out.println(ae);
}
}
}
4)主机服务器 CalculatorServer.java

import java.rmi.Naming;
//一个服务器类
public class CalculatorServer{
public CalculatorServer(){
try{
Calculator c = new CalculatorImpl();
Naming.rebind("rmi://localhost:1099/CalculatorService",c);
}catch(Exception e){
System.out.println("Trobulett:"+e);
}
}
public static void main(String args[]){
new CalculatorServer();
}
}

就是这四个文件,实现一个简单的分布式计算。
第一步:我在命令行编译都通过了:d:\rmiDemo> javac *.java 分别生成相应的.class文件
第二步:使用RMI编译器rmic来生成桩和框架文件,这个编译运行在远程服务实现类文件上。
  d:\rmiDemo> rmic CalculatorImpl
第三步:运行RMI系统 d:\rmiDemo> rmiregistry

第四步:d:\rmiDemo> java -Djava.security.policy=policy.txt CalculatorServer
policy.txt 的内容如下:
grant {
permission java.security.AllPermission "", "";
};
前三步我都能顺利通过。也生成了CalculatorImpl_Stub.class 文件。但是运行第四步的时候,出现错误:
D:\rmiDemo>java -Djava.security.policy=policy.txt CalculatorServer
Trobulett:java.rmi.ServerException: RemoteException occurred in server thread; n
ested exception is:
java.rmi.UnmarshalException: error unmarshalling arguments; nested excep
tion is:
java.lang.ClassNotFoundException: CalculatorImpl_Stub



我的classpath设置为:
classpath=.;D:\Program Files\Java\jdk1.5.0_16\lib;D:\Program Files\Java\jdk1.5.0_16\lib\dt.jar;D:\Program Files\Java\jdk1.5.0_16\lib\tools.jar

请问各位指点一下,非常感谢。



...全文
9540 15 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
lxzhoupeng 2012-08-20
  • 打赏
  • 举报
回复
你好! 我也遇到了同样的问题,能不能详述下你解决的办法! 谢谢!!!
lxzhoupeng 2012-08-20
  • 打赏
  • 举报
回复
你好! 我也遇到了同样的问题,能不能详述下你解决的办法! 谢谢!!!
bingtr 2011-03-22
  • 打赏
  • 举报
回复
遇到了同样的问题
forever_jofyul 2010-12-17
  • 打赏
  • 举报
回复
11楼说的很对。。解答了我的问题。非常感谢。
aquamarine147 2010-11-26
  • 打赏
  • 举报
回复
CalculatorImpl_Stub.class和CalculatorImpl.java虽然位于同一个路径下,但是CalculatorImpl_Stub并非由CalculatorImpl执行行直接加载,而是CalculatorImpl在向RMI注册时,要求rmiregistry去加载 CalculatorImpl_Stub类的,理解了这一层次上的意义就会知道其实 CalculatorImpl_Stub是为 rmiregistry所用的。所以解决办法是:
(1) 在执行 rmiregistry 之前,设置classpath让能查找到CalculatorImpl_Stub类,在同一Dos窗口中
C:\Documents and Settings\unmi>set classpath=%classpath%;D:\rmiDemo
C:\Documents and Settings\unmi>rmiregistry

(2) 或者在命令行中先进入到CalculatorImpl_Stub类所在的目录,然后再执行 rmiregistry (这种方法实质是与上面一样的,只是恰当的应用的classpath中的当前目录 "." ),
aquamarine147 2010-11-25
  • 打赏
  • 举报
回复
今天刚遇到了同样的问题 2L说的不对
出现这个问题的原因是classpath设置的问题
将放置stub的路径添加到classpath中即可
asd289974651 2010-11-25
  • 打赏
  • 举报
回复
顶。。。。
xkaaron 2010-10-14
  • 打赏
  • 举报
回复
要回复啊
PhilosNix 2010-10-11
  • 打赏
  • 举报
回复
遇到了相同问题,忘解释一下2楼
netcat1984 2010-03-16
  • 打赏
  • 举报
回复
看一下是什么问题!!
Technology_What 2010-03-11
  • 打赏
  • 举报
回复
楼主,能告诉我你怎么解决的吗?我也出现了同样的问题
cerlcen 2010-03-10
  • 打赏
  • 举报
回复
看看解决方案,我也遇到同样的问题
hahahappy1986 2009-08-19
  • 打赏
  • 举报
回复
楼上哥们能说下你怎么弄啊哦的吗?
fengyoujie 2008-11-08
  • 打赏
  • 举报
回复
谢谢楼上的那我大哥,不知道是什么原因,现在好了。
hakerivan 2008-11-06
  • 打赏
  • 举报
回复
java.lang.ClassNotFoundException: CalculatorImpl_Stub
是不是没有编译生成CalculatorImpl_Stub 这个文件,
建议:rmic -vcompat CalculatorImpl

67,550

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧