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

原创 2004年08月30日 20:27:00

1.         RMI最简单的一个实例,思路是你在服务器端创建一个方法addData(),该方法实现两个整数的相加,然从客户端远程调用这个方法实现相加功能

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

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.         生成StubSkeleton

在命令提示符下:rmic  AddServerImpl

这时你会发现在文件夹中多了两个文件AddServerImpl_Skel.classAddServerImpl_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.classAddServer.classAddServerImpl_Stub.class放到你打算作为客户端的那台机器上去,注意其它文件不要放,否则你就等于把服务端代码都告诉别人了。

 

 

java远程调用rmi入门实例

RMI是Java的一组拥护开发分布式应用程序的API。RMI使用Java语言接口定义了远程对象,它集合了Java序列化和Java远程方法协议(Java Remote Method Protocol...
  • h348592532
  • h348592532
  • 2014-10-17 13:24:16
  • 2254

Java RMI远程方法调用详解-例子代码

  • 2016年07月22日 17:24
  • 16KB
  • 下载

中间件技术RMI的应用,实现远程调用数据库。

简介中间件是一类连接软件组件和应用的计算机软件,它包括一组服务。以便于运行在一台或多台机器上的多个软件通过网络进行交互。该技术所提供的互操作性,推动了一致分布式体系架构的演进,该架构通常用于支持并简化...
  • han784851198
  • han784851198
  • 2017-03-31 09:13:57
  • 432

Spring RMI实现远程调用及源码

1.RMI简单介绍 Spring除了使用基于HTTP协议的远程调用方案,还为开发者提供了基于RMI机制的远程调用方法,RMI远程调用网络通信实现是基于TCP/IP协议完成的,而不是通过HTTP协议。...
  • clypm
  • clypm
  • 2015-03-10 10:16:51
  • 687

Spring 实现远程访问详解——rmi

Spring为各种远程访问技术提供集成工具类。Spring远程访问通过使用普通POJOs,能更容易的开发远程访问服务。目前,Spring远程访问的主要技术如下: 1. 远程调用RMI(Remote M...
  • a123demi
  • a123demi
  • 2016-04-18 14:13:51
  • 2627

JAVA序列化之RMI远程调用

RMI(Remote Method Invocation)是Java中的远程过程调用(Remote Procedure Call,RPC)实现,是一种分布式Java应用的实现方式。它的目的在于对开发人...
  • u013755987
  • u013755987
  • 2016-07-19 23:24:14
  • 2208

RMI远程方法调用技术

RMI远程方法调用技术
  • wangshuxuncom
  • wangshuxuncom
  • 2015-01-23 15:01:58
  • 2027

使用Spring RMI调用远程方法

Spring有多种调用远程的方式,今天学习了一下远程方法调用(RMI)。 RMI需要服务端和客户端 我们先从服务器开始 我的代码结构 package rmi; ...
  • junshuaizhang
  • junshuaizhang
  • 2014-05-28 19:01:58
  • 5226

Java的RMI远程方法调用实现和应用

https://yq.aliyun.com/articles/38439 最近在学习Dubbo,RMI是很重要的底层机制,RMI(Remote Method Invocation)远程方法调...
  • u012506661
  • u012506661
  • 2017-02-19 21:34:47
  • 891

Java 远程调用 RMI 与Spring的整合实例

spring 与java rmi整合
  • xwh9004
  • xwh9004
  • 2017-08-06 18:16:53
  • 195
收藏助手
不良信息举报
您举报文章:RMI学习笔记(二)-----RMI远程调用实例(一)
举报原因:
原因补充:

(最多只允许输入30个字)