tangbao

导航

<2025年1月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678

统计

常用链接

留言簿

随笔分类

随笔档案

文章分类

文章档案

收藏夹

url

搜索

最新评论

阅读排行榜

评论排行榜

最简单的rmi

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



posted on 2007-05-29 15:13 糖包 阅读(90) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航: