分享

RMI最简单的一个实例

 iversion 2008-07-23
RMI最简单的一个实例
2008年06月21日 星期六 下午 07:30

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的位置,只不过太麻烦。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多