RMI学习笔记(二)-----RMI远程调用实例(一)

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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放到你打算作为客户端的那台机器上去,注意其它文件不要放,否则你就等于把服务端代码都告诉别人了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航