Trobulett:java.rmi.ServerException: RemoteException occurred in server thread; n

Technology_What 2010-03-12 10:43:35
我在网上下载一个学习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
我在此对程序做个说明:
我将所有的文件保存在E:\server\CS2\src这个目录下面总共有四个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



我的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

请问各位指点一下,非常感谢。
...全文
446 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

67,515

社区成员

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

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