- 浏览: 263308 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (88)
- JAVA / base (26)
- JAVA / web (12)
- JAVA / Lib-tools (5)
- SERVER / tomcat (4)
- DB / mysql (4)
- DB / mongodb (2)
- DB / memcached (2)
- DB / redis (2)
- WEB / Front-end (3)
- WEB / security (4)
- WEB / css (2)
- WEB / js (4)
- OS / linux (3)
- IT / Architecture (4)
- IT / other (2)
- Android (9)
- Go (1)
- Other (1)
- OS / Mac (2)
最新评论
-
Zero2Max:
哈哈,马士兵老师也发现了。
java实现接口的bug -
xly1981:
能像CSRF攻击一样带个图就更棒了
XSS跨站攻击 -
xmong:
df274119386 写道在javascript中看到下面的 ...
CSRF攻击与防御策略 -
df274119386:
在javascript中看到下面的语句 e.value = t ...
CSRF攻击与防御策略 -
xmong:
yzxqml 写道xmong 写道yzxqml 写道tomca ...
Tomcat集群
Java Rmi
目录
1 JAVA RMI 1
1.1 RMI简介 1
2 JAVA RMI的实现 1
2.1 JAVA RMI简单实现 1
1 Java RMI
1.1 RMI简介
Java RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。
RMI的工作原理:正常情况下,在同一个Java虚拟机中一个对象调用另一个对象的方法,要向该方法传递对象参数,以及获取方法返回值对象,这些都可以通过引用(指向Java虚拟机内存中的对象)来完成,这称为传引用。但是RMI远程调用方法是在不同虚拟机中来完成方法调用,这种传值方法就不适用了。因为不同Java虚拟机中同一个引用值指向的对象是不一样的,同时也可能不同的虚拟机引用的实现方式完全不同和不兼容。
因此为了实现向远程方法传递参数和获取远程方法返回结果,可以使用三种机制来实现,这取决于所传递的数据类型:
简单数据类型(int,Boolean,double等)是按值传递来完成的,这和本地java方法调用的值传递一样。
远程对象的引用(即实现了Remote接口的对象)是以远程引用(Remote Reference)传递来完成的,即允许接收方调用远程对象上的方法。这与本地java方法调用传递对象引用有些相似。
没有实现Remote接口的对象是按值来传递的,即通过对象序列化来传递整个对象的副本。
Java Rmi的通信机制就是根据上面传递机制来实现的。
2 JAVA RMI的实现
要实现RMI远程对象调用需要大部分类都在java.rmi,java.rmi.server和java.rmi.registry包中。
Java.rmi包定义了客户端所见的类,接口和异常。
Java.rmi.server包定义了服务器端可见的类,接口和异常。
Java.rmi.registry包定义了用于查找和命名远程对象的类,接口和异常。
2.1 Java RMI简单实现
HelloRmi:rmi服务接口
HelloRmiImpl:rmi服务实现类
Server:RMI服务器端类
Client:RMI客户端类
HelloRmi实现如下:
HelloRmiImpl实现如下:
Server实现如下:
Client实现如下:
执行结果如下:
运行Server
Server输出:
运行Client
Client输出:
Server输出:
目录
1 JAVA RMI 1
1.1 RMI简介 1
2 JAVA RMI的实现 1
2.1 JAVA RMI简单实现 1
1 Java RMI
1.1 RMI简介
Java RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。
RMI的工作原理:正常情况下,在同一个Java虚拟机中一个对象调用另一个对象的方法,要向该方法传递对象参数,以及获取方法返回值对象,这些都可以通过引用(指向Java虚拟机内存中的对象)来完成,这称为传引用。但是RMI远程调用方法是在不同虚拟机中来完成方法调用,这种传值方法就不适用了。因为不同Java虚拟机中同一个引用值指向的对象是不一样的,同时也可能不同的虚拟机引用的实现方式完全不同和不兼容。
因此为了实现向远程方法传递参数和获取远程方法返回结果,可以使用三种机制来实现,这取决于所传递的数据类型:
简单数据类型(int,Boolean,double等)是按值传递来完成的,这和本地java方法调用的值传递一样。
远程对象的引用(即实现了Remote接口的对象)是以远程引用(Remote Reference)传递来完成的,即允许接收方调用远程对象上的方法。这与本地java方法调用传递对象引用有些相似。
没有实现Remote接口的对象是按值来传递的,即通过对象序列化来传递整个对象的副本。
Java Rmi的通信机制就是根据上面传递机制来实现的。
2 JAVA RMI的实现
要实现RMI远程对象调用需要大部分类都在java.rmi,java.rmi.server和java.rmi.registry包中。
Java.rmi包定义了客户端所见的类,接口和异常。
Java.rmi.server包定义了服务器端可见的类,接口和异常。
Java.rmi.registry包定义了用于查找和命名远程对象的类,接口和异常。
2.1 Java RMI简单实现
HelloRmi:rmi服务接口
HelloRmiImpl:rmi服务实现类
Server:RMI服务器端类
Client:RMI客户端类
HelloRmi实现如下:
package com.rmi; import java.rmi.Remote; import java.rmi.RemoteException; /** * 定义一个rmi服务接口,rmi接口必须继承Remote接口, * 其中需要远程调用的方法必须抛出RemoteException异常 * @author xmong */ public interface HelloRmi extends Remote{ /** * 简单实现的say hi方法 * @param name * @return * @throws RemoteException */ public String sayHi(String name) throws RemoteException; }
HelloRmiImpl实现如下:
package com.rmi; import java.rmi.RemoteException; import java.rmi.server.UnicastRemoteObject; /** * rmi接口实现,rmi实现继承了UnicastRemoteObject类, * UnicastRemoteObject类提供了很多支持远程调用的方法。 * @author xmong */ public class HelloRmiImpl extends UnicastRemoteObject implements HelloRmi{ /** * 序列化对象 */ private static final long serialVersionUID = 1L; /** * 因为UnicastRemoteObject的构造方法抛出了RemoteException异常, * 因此这里默认的构造方法必须写,必须声明抛出RemoteException异常 * @throws RemoteException */ protected HelloRmiImpl() throws RemoteException { super(); } /** * 传入一个客户端名称字符串,对该名称问候,输出客户端名称和 ip * 返回客户端名称“Server” */ @Override public String sayHi(String name) throws RemoteException{ try { //UnicastRemoteObject的getClientHost()获取客户端主机名 System.out.println("Server: Hi "+name+" "+getClientHost()); } catch (ServerNotActiveException e) { e.printStackTrace(); } return "Server"; } }
Server实现如下:
package com.rmi; import java.net.MalformedURLException; import java.rmi.AlreadyBoundException; import java.rmi.Naming; import java.rmi.RemoteException; import java.rmi.registry.LocateRegistry; /** * 创建RMI注册表,启动RMI服务,并将远程对象注册到RMI注册表中。 * @author xmong */ public class Server { public static void main(String[] args) { try { //创建远程服务对象 HelloRmi hr = new HelloRmiImpl(); /** * 在本机上注册远程服务端口9999,这一步必不可少, * 缺少注册表创建,则无法绑定远程服务对象到远程注册表上 ,启动时会抛出Connection refused异常。 * java默认端口为1099,可以通过Registry.REGISTRY_PORT来获取这个值 */ LocateRegistry.createRegistry(9999); /** * 把远程服务对象注册到服务器上命名为:hello * /绑定的URL标准格式为:rmi://host:port/name * 其中协议名可以省略,即[rmi:]可以省去 */ Naming.bind("rmi://localhost:9999/hello", hr); System.out.println("Rmi Server bind success"); } catch (RemoteException e) { System.out.println("创建远程服务对象异常!"); e.printStackTrace(); } catch (MalformedURLException e) { System.out.println("绑定远程URL发生异常!"); e.printStackTrace(); } catch (AlreadyBoundException e) { System.out.println("发生重复绑定异常!"); e.printStackTrace(); } } }
Client实现如下:
package com.rmi; import java.net.MalformedURLException; import java.rmi.Naming; import java.rmi.NotBoundException; import java.rmi.RemoteException; /** * 客户端测试,客户端远程访问服务对象方法。 * @author xmong */ public class Client { public static void main(String[] args) { try { /** * 在RMI服务注册表中查找名称为RHello的对象,并调用其上的方法 */ HelloRmi hr = (HelloRmi)Naming.lookup("rmi://localhost:9999/hello"); //调用服务方法 System.out.println("Client: Hi "+hr.sayHi("Client")); } catch (MalformedURLException e) { e.printStackTrace(); } catch (RemoteException e) { e.printStackTrace(); } catch (NotBoundException e) { e.printStackTrace(); } } }
执行结果如下:
运行Server
Server输出:
Rmi Server bind success
运行Client
Client输出:
Client: Hi Server
Server输出:
Server: Hi Client 172.30.39.227
发表评论
-
Java validation(java验证器实现)
2014-03-18 11:45 3698Java validation 1. java验证器 在 ... -
Memo class备注类信息
2014-03-18 09:52 891Memo Class 1. 什么是Memo Class Mem ... -
java annotation注解
2014-01-24 18:01 9501. Annotation的声明方式 An ... -
java内部类
2013-03-19 16:25 1044Java内部类 目录 1 JAVA ... -
java多线程设计模式之订单模式
2013-03-11 14:00 2693Java多线程实现订单模式: 客户端线程向服务端发起请求后, ... -
java多线程设计模式之线程池处理请求
2013-03-08 17:50 1825Java实现线程池处理请求: 客户端线程发出请求,请求存入请 ... -
java多线程设计模式之异步处理请求
2013-03-08 12:36 4527Java实现多线程异步处理请求: Java实现多线程异步处理 ... -
java多线程设计模式之读写文件模式
2013-03-07 17:56 1589Java实现多线程读写数据 ... -
java多线程设计模式之生产者与消费者
2013-03-07 11:34 1064Java实现多线程生产者与消费者: 生产者线程负责生产产品 ... -
java多线程设计模式之文件保存
2013-03-06 16:16 1611Java实现多线程保存文件:两线程去保存文件,一个保存线程定时 ... -
java多线程设计模式之队列通信
2013-03-06 13:51 2493Java实现多线程处理队列请求通信:客户端线程向请求队列中不断 ... -
Java读linux系统文件文件名乱码
2012-12-06 17:01 91651,问题描述 web应用想通过Java读取linux系统文件显 ... -
Java安全加密
2012-11-28 10:24 1989安全加密 目录 1 加密安全 1 1.1 应用的安全 1 ... -
图着色问题
2012-11-27 13:05 3121图着色问题 目录 1 图 ... -
JDK6新特性
2012-07-03 23:24 2901JDK6的新特性 JDK6的新特性之一_Desktop类 ... -
JDK7新特性
2012-07-03 15:39 3513JDK7新特性 一 JDK7新特性简介 准备 JDK7下载 ... -
JDK5新特性
2012-07-03 10:23 73JDK5.0新特性 1.自动封箱和自动解封(简单类型和封装类 ... -
java多线程
2012-06-15 15:12 1574Java多线程 目录 1 线 ... -
代理模式
2012-06-13 14:12 1382代理模式 目录 1 代理 ... -
java垃圾回收机制
2012-06-11 11:30 2566Java内存回收 目录 1 JAVA内存STACK和HE ...
相关推荐
**基于JAVA RMI的聊天室** Java Remote Method Invocation(RMI)是Java平台提供的一种用于在分布式环境中调用远程对象的方法。在这个“基于JAVA RMI的聊天室”项目中,开发者利用RMI技术构建了一个简单的多用户...
Java RMI(Remote Method Invocation)技术是Java平台中用于分布式计算的一种机制,它允许一个Java对象调用远程计算机上的另一个Java对象的方法。在本案例中,“java RMI技术实现的网络聊天室”是一个使用RMI构建的...
Java RMI(Remote Method Invocation,远程方法调用)是一种Java技术,允许在分布式环境中执行远程对象的方法。这个技术的核心是序列化和反序列化过程,它使得对象可以在网络上进行传输。然而,这个特性也可能引入...
根据提供的文件信息,我们可以深入探讨Java RMI(Java Remote Method Invocation)的相关知识点,包括其概念、原理、体系结构以及一个具体的示例。 ### RMI的概念 RMI是一种Java技术,它允许开发者创建分布式应用...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行远程对象的调用。RMI使得开发者可以像调用本地对象一样调用网络上的对象,极大地简化了...
Java Remote Method Invocation(Java RMI)是Java编程语言中用于在网络间进行远程对象调用的技术。它是Java平台的标准部分,允许程序员在分布式环境中调用对象的方法,就像它们在同一台计算机上一样。Java RMI对于...
### Java RMI (Remote Method Invocation) 概念与实践 #### 一、Java RMI简介 Java RMI(Remote Method Invocation)是一种允许调用不同Java虚拟机(JVM)上方法的机制。这些JVM可能位于不同的机器上,也可能在同一...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同网络节点上的Java对象之间进行透明的交互。在Java RMI中,一个对象可以调用另一个位于不同JVM(Java虚拟机)...
Java RMI (Remote Method Invocation) 是一种用于在Java应用程序之间进行远程通信的技术。为了提高RMI通信的安全性,我们可以使用SSL (Secure Sockets Layer) 或其后继者TLS (Transport Layer Security) 进行加密。...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种用于分布式计算的技术,它允许一个Java对象调用另一个在不同 JVM(Java虚拟机)上的对象的方法。这个简单的示例展示了如何创建一个基本的...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台中用于构建分布式对象系统的关键技术。它允许Java应用程序在不同Java虚拟机(JVM)之间进行远程方法调用,这些虚拟机可能位于同一台计算机或网络上的...
Java RMI(Remote Method Invocation)是Java编程语言中用于实现远程过程调用的一种技术。它允许运行在客户机上的程序调用位于远程服务器上的对象的方法,从而实现分布式计算。RMI的核心思想是通过接口隐藏底层网络...
**JAVA RMI(远程方法调用)详解** Java RMI(Remote Method Invocation)是Java平台上的一个核心特性,它允许Java程序在不同的JVM(Java虚拟机)之间进行分布式计算,实现了对象间的远程调用。RMI使得开发者可以像...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种用于分布式计算的技术,它允许一个Java对象调用另一个在不同JVM上的对象的方法。这个简单的例子将引导我们了解如何利用Java RMI实现远程...
Java RMI,全称为Remote Method Invocation,是Java平台上的一个标准API,用于实现分布式计算,使得在不同Java虚拟机(JVM)上的对象能够互相调用方法。这个"java rmi HelloWorld版(源码)"的压缩包文件提供了一个...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许Java对象在不同的网络环境中进行交互,就像调用本地方法一样。RMI是构建分布式应用的重要工具,尤其适用于需要跨...
Java Remote Method Invocation (RMI) 是Java平台提供的一种强大的分布式计算技术,允许在不同网络环境中的Java对象之间进行远程方法调用。这个可运行实例是一个实际应用RMI概念的示例,它展示了如何构建和运行一个...
Java RMI 完整版 Java Remote Method Invocation(RMI)是一种分布式对象技术,允许使用 Java 编写分布式对象,不同的 Java 虚拟机(JVM)之间进行对象间的通讯。这使得应用程序(Application)可以远程调用方法,...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行方法调用,仿佛这些方法都在本地对象上执行一样。这个"JAVA RMI简单例子"旨在帮助我们...