Java远程方法调用(RMI)提供了Java程序语言的远程通讯功能,这种特性使客户机上运行的程序可以调用远程服务器上的对象,使Java编程人员能够在网络环境中分布操作。
创建一个简单的Java分布式远程方法调用程序可以按以下几个步骤操作,
一、定义远程接口:
在 Java 中,远程对象是实现远程接口的类的实例, 远程接口声明每个要远程调用的方法。在需要创建一个远程对象的时候,我们通过传递一个接口来隐藏基层的实施细节,客户通过接口句柄发送消息即可。
远程接口具有如下特点:
1) 远程接口必须为public属性。如果不这样,除非客户端与远程接口在同一个包内,否则 当试图装入实现该远程接口的远程对象时,调用会得到错误结果。
2) 远程接口必须扩展接口java.rmi.Remote。
3) 除与应用程序本身特定的例外之外,远程接口中的每个方法都必须在自己的throws从句中 声明java.rmi.RemoteException。(或RemoteException 的父类)。
4) 作为参数或返回值传递的一个远程对象(不管是直接,还是本地对象中嵌入)必须声明为远 程接口,而不应声明为实施类。
下面是远程接口的接口RmiSample的定义
import java.rmi.*;
public interface RmiSample extends Remote {
public int sum(int a,int b) throws RemoteException;
}
二、实现远程接口:
远程对象实现类必须扩展远程对象java.rmi.UnicastRemoteObject类,并实现所定义的远程接口。远程对象的实现类中包含实现每个远程接口所指定的远程方法的代码。这个类也可以含有附加的方法,但客户只能使用远程接口中的方法。因为客户是指向接口的一个句柄,而不是它的哪个类。必须为远程对象定义构造函数,即使只准备定义一个默认构造函数,用它调用基础类构造函数。因为基础类构造函数可能会抛出java.rmi.RemoteException,所以即使别无它用必须抛出java.rmi.RemoteException例外。
以下是远程对象实现类的声明:
import java.rmi.*;
import java.rmi.server.*;
public class RmiSampleImpl extends UnicastRemoteObject
implements RmiSample {
RmiSampleImpl() throws RemoteException {
super();
}
public int sum(int a,int b) throws RemoteException {
return a + b;
}
}
三、编写服务器类:
包含 main 方法的类可以是实现类自身,也可以完全是另一个类。下面通过RmiSampleServer 来创建一个远程对象的实例,并通过java.rmi.registry.LocateRegistry类的createRegistry 方法从指定端口号启动注册服务程序,也可以通过执行 rmiregistry 命令启动注册服务程序,注册服务程序的缺省运行端口为 1099。必须将远程对象名字绑定到对远程对象的引用上:Naming.rebind("//localhost:8808/SAMPLE-SERVER" , Server);
以下是服务器类的声明:
import java.rmi.*;
import java.rmi.registry.*;
public class RmiSampleServer{
public static void main(String args[]) {
try {
LocateRegistry.createRegistry(8808) ;
SampleServerImpl Server = new SampleServerImpl();
// 将该对象实例与名称“SAMPLE-SERVER”捆绑
Naming.rebind("//localhost:8808/SAMPLE-SERVER" , Server);
} catch (java.net.MalformedURLException me) {
System.out.println("Malformed URL: " + me.toString());
} catch (RemoteException re) {
System.out.println("Remote exception: " + re.toString());
}
}
}
四、编写使用远程服务的客户机类:
客户机类的主要功能有两个,一是通过Naming.lookup方法来构造注册服务程序 stub 程序实例,二是调用服务器远程对象上的远程方法。
以下是服务器类的声明:
import java.rmi.*;
import java.rmi.server.*;
public class RmiSampleClient {
public static void main(String[] args)
{
try {
String url = "//localhost:8808/SAMPLE-SERVER";
RmiSample RmiObject = (RmiSample)Naming.lookup(url);
System.out.println(" 1 + 2 = " + RmiObject.sum(1,2) );
} catch (RemoteException exc) {
System.out.println("Error in lookup: " + exc.toString());
} catch (java.net.MalformedURLException exc) {
System.out.println("Malformed URL: " + exc.toString());
} catch (java.rmi.NotBoundException exc) {
System.out.println("NotBound: " + exc.toString());
}
}
}
五、编译代码:
要编译 Java 源文件,请运行 javac 命令:
javac RmiSample.java RmiSampleImpl.java RmiSampleServer.java RmiSampleClient.java
六、为远程对象实现创建根和干:
要创建存根程序和骨架文件,应以包含远程对象实现的已编译类包全名运行 rmic 编译器。
存根(Stub)是远程对象在客户端的代理,它将RMI调用传递给服务器端的骨架(Skeleton),后者负责将该调用传递给实际的远程方法输入如下:
D:\RMI>rmic -d D:\RMI RmiSampleImpl
执行这个命令, 若rmic成功运行,RMI目录下就会多出两个新类: RmiSampleImpl_Stub.class RmiSampleImpl_Skel.class 它们分别对应的是存根(stub)和骨架(skeleton).
七、运行代码:
运行服务端程序:在Windows下,输入下列命令,在后台启动RmiSampleServer程序:
D:\RMI>java RmiSampleServer
运行客户端程序:
D:\RMI>java RmiSampleClient
客户端输出: 1 + 2 = 3
分享到:
相关推荐
其他IDE稍做修改就行,源码不依赖其他JAR包,所以容量很小,服务端主窗口为表格,可以打开预览窗口(屏幕墙),预览在线客户端画面,可以控制在线的电脑,另外包含功能:开机(客户端处理关机状态且打开远程唤醒的...
java项目之网络远程作业处理系统源码java项目之网络远程作业处理系统源码java项目之网络远程作业处理系统源码java项目之网络远程作业处理系统源码java项目之网络远程作业处理系统源码java项目之网络远程作业处理系统...
有源码 , 著名的 java 远程监控程序JSN,结合了N种设计模式,功能强大,功能特点:隐蔽运行,桌面图像监控,鼠标键盘控制,文件上传,下载,远程重启,关机。邮件通知,WEB监控,等等,附有详细的使用教程。 程序易...
【完整课程列表】 java教学大纲.doc 优质精品课程推荐 武汉...优质精品课程推荐 武汉大学Java语言程序设计教程 第11章 java远程方法调用.ppt 优质精品课程推荐 武汉大学Java语言程序设计教程 序论 面向对象的概念.ppt
Java远程方法调用是一种分布式系统技术。它允许一个java虚拟机调用运行在网络中另一个地方的JVM上的对象方法. 这种技术对开发大型系统尤为重要,因为它使得在多台机器上分布资源和处理负载的想法成为可能。
(java毕业设计)JSP+sql网络远程作业处理系统(系统+论wen+开题报告+中英文摘要+封面+目录+资料).(java毕业设计)JSP+sql网络远程作业处理系统(系统+论wen+开题报告+中英文摘要+封面+目录+资料).(java毕业设计)...
基于Java Web和Matlab Builder JA的远程数学实验教学系统设计.pdf
Web 远程仿真实验系统的数值计算及图形处理由Matlab 实现,运用Matlab Java Builder 将Matlab 代码转化为Java 类,在服务器端技术Servlet 及JSP 中去调用转化而来的Java 类,并将用户的请求参数,进行包装传递到Matlab ...
的文件发送给客户端,对于服务端有而客户端没有的文件也需要发送给客户端,处理完所 有File后,服务端将本地的history.htm与传送给客户端,并通知客户端更新完毕;客户端收 到更新完毕后的应答后自动打开history.htm...
windows下java处理视频的源码,功能有,获取视频格式转码、视频缩略图截取、视频切割、获取视频相关信息等。与“windows下java调用ffmpeg视频处理环境搭建”配套使用。
java 访问网络 下载文件 爬虫 超时处理解决方案
屏幕抓取技术: 使用Java图像处理库实现将远程计算机屏幕内容传输到监控端。 数据加密: 对传输的数据进行加密处理,确保数据传输的安全性。 应用场景: 远程技术支持: 可用于远程支持员工解决电脑问题,无需现场...
服务器端:部署在管理员端的服务器程序,接收和处理来自客户端的监控数据,提供远程控制和管理功能。 管理界面:管理员通过管理界面登录系统,查看监控画面、执行远程操作等。 技术实现: 远程桌面协议:使用基于...
以下是对Scala-SDK、向日葵(远程工具)和阿里Java代码规范的简单介绍: 1. Scala-SDK:Scala-SDK是一种用于开发Scala语言的软件开发工具包。Scala是一种现代的多范式编程语言,结合了面向对象编程和函数式编程的...
java.awt.event 提供处理由 AWT 组件所激发的各类事件的接口和类。 java.awt.font 提供与字体相关的类和接口。 java.awt.geom 提供用于在与二维几何形状相关的对象上定义和执行操作的 Java 2D 类。 java.awt.im ...
处理Java开发中的,访问异常.源代码,有视频的,可以联系我
RMI使用Java语言接口定义了远程对象,它集合了Java序列化和Java远程方法协议(Java Remote Method Protocol)。简单地说,这样使原先的程序在同一操作系统的方法调用,变成了不同操作系统之间程序的方法调用,由于...
Java多线程读大文件 java多线程写文件:多线程往队列中写入数据
Java波浪文字,一个利用Java处理字符的实例,可以设置运动方向参数,显示文本的字符数组,高速文本颜色,显示字体的 FontMetrics对象,得到Graphics实例,得到Image实例,填充颜色数组数据,初始化颜色数组。...