RMI最简单的一个实例

来源:百度文库 编辑:神马文学网 时间:2024/04/26 04:14:53
2008年06月21日 星期六 下午 07:30
[转载:http://hi.baidu.com/sham%5Frock/blog/item/2beb8a4cd01d5ffad72afc4e.html]
1.    RMI最简单的一个实例,思路是你在服务器端创建一个方法addData(),该方法实现两个整数的相加,然从客户端远程调用这个方法实现相加功能
2.    我们一步一步来实现,首先定义远程接口-----远程接口类
import java.rmi.*;
import java.rmi.server.*;
public interface AddServer extends Remote
{
public int addData(int a,int b)throws RemoteException;
}
2.         定义和实现服务器中远程方法-----服务器类
import java.rmi.*;
import java.rmi.server.*;
//注意要扩展UnicastRemoteObject类
public class AddServerImpl extends UnicastRemoteObject implements AddServer{
public AddServerImpl()throws RemoteException
{
super();
}
public int addData(int a,int b)throws RemoteException
{
return a+b;
}
public static void main(String s[]){
try{
//创建该远程对象
AddServerImpl instance=new AddServerImpl();
//注册该远程对象
Naming.rebind("add",instance);
System.out.println("Server Registered");
}
catch(Exception e){System.out.println(e);}
}
}
3.         定义与实现客户-----客户类
import java.io.*;
import java.rmi.*;
public class AddClient{
public AddClient(){
try{
BufferedReader input=new BufferedReader(new InputStreamReader(System.in));
System.out.println("Please enter first number:");
System.out.flush();
String s=input.readLine();
int num1=Integer.parseInt(s);
System.out.println("Please enter second number:");
System.out.flush();
s=input.readLine();
int num2=Integer.parseInt(s);
AddServer addserver=(AddServer)Naming.lookup("rmi://127.0.0.1/add");
int i=addserver.addData(num1,num2);
System.out.print("Result is:"+i);
}catch(Exception e){System.out.println(e);}
}
public static void main(String s[]){
new AddClient();
}
}
4.         编译javac *.java
5.         生成Stub和Skeleton
在命令提示符下:rmic  AddServerImpl
这时你会发现在文件夹中多了两个文件AddServerImpl_Skel.class和AddServerImpl_Stub.class
6.         创建安全策略
在命令提示符下:policytool
点击Add Policy Entry按钮,点击Add Permission按钮,
在Permission列表框中选取:AllPermission            点击ok              点击Done按钮
从File菜单总选择Save as,打入文件名“.java.policy”,注意这里的文件名前有“.”前缀,接着保存在你那个登录用户名的文件夹下面。
7.         启动RMI远程注册表
在命令提示符下:start  rmiregistry
8.         启动服务器
在命令提示符下:java  AddServerImpl
9.         启动客户
在命令提示符下:java  AddClient
10.   如果你是在自己机器上调试的话,那么到第九步就可以了,如果你在两台机器上调试的话,需要改一下AddClient代码中的IP地址,并且把AddClient.class,AddServer.class和AddServerImpl_Stub.class放到你打算作为客户端的那台机器上去,注意其它文件不要放,否则你就等于把服务端代码都告诉别人了。
解决“找不到Stub类”错误:
启动rmiRegistry并运行自己的远程服务器和客户程序。
1)服务器的运行
先在DOS下运行 rmiregistry,这个命令是开启RMI的注册服务,开启以后我们的server程序才能调用rebing方法发布我们的类。
然后,运行我们的server程序 AddServer,这里是最容易出错的,参见下面注意事项。
注意:  如果提示找不到Stub类,这个需要用下面的命令来运行java.exe -Djava.rmi.server.codebase=file://E:\MIS_Interface\momo\TestEasy\classes/
RMI_Server蓝字部分指定了stub类的路径,该路径最后一定要加"/"表示目录。有人会问,我已经把stub 通过-classpath 加到类路径里面了,为什么还没有提示这个错误呢?原因是这样的: 这里提示的找不到stub类,不是由你写的RMI_Server这个程序引起的,是由rmi注册服务器报告的异常,也就是我们前面启动的 rmiregistry ,因为你写的RMI_Server 要求RMI注册服务器注册一个新的类,自然RMI服务器必须知道你的类放在哪里,所以我们通过 -Djava.rmi.server.codebase 这个运行参数来指定你也可以通过修改操作系统的classpath 环境变量 来指定stub的位置,只不过太麻烦。