- 浏览: 290005 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
86614009:
如何在service层,如何获取绑定到当前线程的entitna ...
使用spring的OpenEntityManagerInView -
yajunyajun2011:
好帖子 怎么没人顶呢
Java 正则表达式最大,最小匹配问题 -
xtuali:
能说明一下,你的nutch是哪个版本的吗?谢谢!
搜索引擎Nutch源代码研究之一 网页抓取(1) -
dongmusic:
需要学习这么多的东西,吐血中...
如何提高Java开发能力 -
jiminsc:
cool
LDAP 验证、添加、修改、删除(转)
另一篇文章也很好,收藏了:
http://ajava.org/course/java/16865.html
8.1 RemoteStub 类
java.rmi.server.RemoteStub 类是远程对象 stub 的通用超类。stub 对象是一种代理,它支持的远程接口集与远程对象的实际实现所定义的完全相同。
package java.rmi.server;
public abstract class RemoteStub extends java.rmi.RemoteObject {
protected RemoteStub();
protected RemoteStub(RemoteRef ref);
protected static void setRef(RemoteStub stub, RemoteRef ref);
}
RemoteStub 的第一个构造函数将创建带有空远程引用的 stub。第二个构造函数将创建带有给定远程引用 ref 的 stub。
JDK1.2 中不鼓励使用(且不支持)setRef 方法。
8.1.1 远程对象与 stub 类的类型等价性
客户机可与 stub(代理)对象进行交互,该 stub 的远程接口集与远程对象类所定义的完全相同。由于 stub 类是由实现一个或多个远程接口的实现类精华所生成的,因此 stub 类不包括类层次(组成对象的类型图)的非远程部分。例如,
如果 C 扩展 B 而 B 扩展 A,但只有 B 实现远程接口,则 stub 将由 B 生成,而非 C。
由
于 stub 实现与远程对象类相同的远程接口集,因此从 Java 系统的角度看,stub
拥有与服务器对象类型图的远程部分相同的类型。这样,客户机即可利用内置 Java
操作来检查远程对象的类型,同时也可从一个远程接口向另一远程接口进行强制类型转换。
stub 是用 rmic 编译器生成的。
8.1.2 声明为终态的对象方法的语义
以下方法在 java.lang.Object 类中被声明为终态 final,因此不能被任意实现所覆盖:
getClass
notify
notifyAll
wait
getClass
的缺省实现适用于所有 Java 对象(本地或远程);对于远程对象,该方法不需要专门的实现。getClass 方法在远程 stub
上使用时,它报告由 rmic 生成的 stub 对象的确切类型。注意,stub 类型仅反映远程对象实现的远程接口,而非本地接口。
java.lang.Object
的 wait 和 notify 方法将处理 Java 语言线程模型上下文中的等待和通知。虽然对远程 stub 使用这些方法不会违反 Java
线程模型,但这些方法的语义将与用于本地 Java 对象时的语义不同。尤其,使用这些方法时所操作的将是远程对象的客户机本地引用
(stub),而不是远程站点的实际对象。
8.2 RemoteCall 接口
RemoteCall 是远程对象的 stub 和 skeleton 所用的抽象接口,用来执行对远程对象的调用。
----------------------------------------------------------------------
注意 - JDK 1.2 中不鼓励使用 RemoteCall 接口。JDK 1.2 stub 协议也已不再使用此接口。现在,stub 在 JDK 1.2 中使用新的 invoke 方法,该方法不需要将 RemoteCall 作为参数。
----------------------------------------------------------------------
package java.rmi.server;
import java.io.*;
public interface RemoteCall { ObjectOutput getOutputStream() throws IOException;
void releaseOutputStream() throws IOException;
ObjectInput getInputStream() throws IOException;
void releaseInputStream() throws IOException;
ObjectOutput getResultStream(boolean success)
throws IOException, StreamCorruptedException;
void executeCall() throws Exception;
void done() throws IOException;
}
方法 getOutputStream 返回输出流。stub 将把参数编组到其中,或者 skeleton 将把结果编组到其中。
方法 releaseOutputStream 释放输出流。在某些传输中,这将导致释放流。
方法 getInputStream 返回 InputStream。stub 从中解编结果,或者 skeleton 从中解编参数。
方法 releaseInputStream 释放输入流。这将允许某些传输提前释放连接的输入端。
方
法 getResultStream 返回输出流(写完与调用成功有关的标题信息后)。每次远程调用将只能获得一次结果流。如果 success
为真,则要编组的结果属于正常返回;否则结果为异常。如果已获得该远程调用的结果流,则抛出 StreamCorruptedException。
方法 executeCall 尽其所能执行调用。
方法 done 允许完成远程调用后进行清除。
8.3 RemoteRef 接口
接口 RemoteRef 表示远程对象的句柄。每个 stub 均包含 RemoteRef 的一个实例,其中包含引用的具体表示。该远程引用将用来在其代表的远程对象上执行远程调用。
package java.rmi.server;
public interface RemoteRef extends java.io.Externalizable { Object invoke(Remote obj,
java.lang.reflect.Method method, Object[] params, long opnum) throws Exception;
RemoteCall newCall(RemoteObject obj, Operation[] op, int opnum, long hash)
throws RemoteException;
void invoke(RemoteCall call) throws Exception;
void done(RemoteCall call) throws RemoteException;
String getRefClass(java.io.ObjectOutput out);
int remoteHashCode();
boolean remoteEquals(RemoteRef obj);
String remoteToString();
}
第
一个 invoke 方法将方法调用代理给 stub (obj) 的远程引用,并允许引用负责建立对远程主机的连接,将 method 和参数
params 的一些表示进行编组,然后使用方法调用与远程主机进行通讯。该方法将返回驻留在远程主机上的远程对象的方法调用结果,或者在调用失败时抛出
RemoteException,而在远程调用抛出异常时则抛出应用程序级异常。注意,操作号 opnum
表示一散列方法签名,可以用来对要传输的方法进行编码。
opnum 的方法散列是一个 64 位(长)整数,是根据美国国家标准技术局
(NIST) 的安全散列算法 (SHA-1),用字节流消息摘要的前两个 32
位值计算而来的。字节流包含由远程方法名后跟其方法描述符组成的字符串的 UTF 编码(有关方法描述符的说明,参见 Java 虚拟机规范的第
4.3.3 节)。散列值将从 SHA-1 散列的第一个和第二个 32 位值得到。
long hash = sha[1] << 32 + sha[0]
----------------------------------------------------------------------
注
意 - JDK 1.2 中不鼓励使用 newCall、invoke 和 done 方法。rmic 用 JDK 1.2 stub 协议版本生成的
stub 不再使用这些方法。由 newCall、invoke 和 done 组成的调用序列已被新的 invoke 方法所替换,该新方法将
Method 对象作为一个参数。
----------------------------------------------------------------------
方
法 newCall 将为远程对象 obj 上的新远程方法调用创建相应的调用对象。操作数组 op 包含远程对象上的可用操作。操作号 opnum
是对操作数组的索引,它指定该远程调用的特定操作。 传递操作数组和索引可使 stub
生成器能分派操作索引并进行解释。远程引用可能需要操作说明以在调用中进行编码。
方法 invoke 负责执行远程调用。invoke 将产生能顺利通过而不被 stub 捕获的“用户”异常。如果在远程调用过程中产生异常,则 invoke 应注意在产生“用户异常”或 RemoteException 之前清除连接。
方法 done 允许远程引用清除(或重新使用)连接。只有当 invoke 调用已成功地(非异常)返回 stub 时,才应调用 done。
方法 getRefClass 返回将被序列化到流 out 上的引用类型的非包限定的类全名。
方
法 remoteHashCode 返回远程对象的散列码。两个引用相同远程对象的远程对象 stub
将有相同的散列码(以支持在散列表中将远程对象作为键值)。RemoteObject 将把对其 hashCode 方法的调用转发给远程引用的
remoteHashCode 方法。
方法 remoteEquals
比较两个远程对象的等价性。如果两个远程对象引用相同的远程对象,即认为它们等价。例如,如果两个 stub 引用相同的远程对象,则认为它们等价。
RemoteObject 将把对其 equals 方法的调用转发给远程引用的 remoteEquals 方法。
方法 remoteToString 返回表示该远程对象的引用的 String。
8.4 ServerRef 接口
接口 ServerRef 表示远程对象实现的服务器端句柄。
package java.rmi.server;
public interface ServerRef extends RemoteRef {
RemoteStub exportObject(java.rmi.Remote obj, Object data)
throws java.rmi.RemoteException;
String getClientHost() throws ServerNotActiveException;
}
方法 exportObject 将为所提供的 Remote 对象实现 obj 查找或创建客户机 stub 对象。参数 data 包含导出对象所需的信息(如端口号)。
方法 getClientHost 返回当前客户机的主机名。当它被当前正在处理远程对象调用的线程调用时,将返回执行此调用的客户机主机名。如果当前某一远程方法调用未处于服务状态,则调用 ServerNotActiveException。
8.5 Skeleton 接口
接口 Skeleton 仅能由 rmic 编译器所生成 skeleton 的实现。远程对象的 skeleton 是服务器端的实体,它将为实际远程对象实现分配调用。
注
意 - JDK1.2 中不鼓励使用 Skeleton 接口。每个由 rmic stub 编译器生成的 1.1(以及在 1.2 中由缺省
rmic -vcompat 生成的兼容 1.1 的 skeleton)skeleton 类均实现该接口。JDK1.2
兼容版本中分配远程方法调用将不再需要 skeleton。要生成兼容 JDK1.2 或更高版本的 stub,请使用带有选项 -v1.2 的命令
rmic。
package java.rmi.server;
public interface Skeleton {
void dispatch(Remote obj, RemoteCall call, int opnum, long hash) throws Exception;
Operation[] getOperations();
}
dispatch 方法将解编 call 对象中获得的输入流中的参数,调用实际远程对象实现 obj 上的方法(由操作号 opnum 表示),然后将返回值进行编组。如果在调用过程中发生异常,则抛出异常。
getOperations 方法返回包含远程对象方法的操作描述符的数组。
8.6 Operation 类
类 Operation 包含对远程对象 Java 方法的说明。
----------------------------------------------------------------------
注
意 - JDK 1.2 中不鼓励使用 Operation 接口。JDK 1.2 stub 协议不再使用原有的、以 Operation 作为参数的
RemoteRef.invoke 方法。stub 在 JDK 1.2 中使用了新的 invoke 方法,它不再需要将 Operation
作为参数。
----------------------------------------------------------------------
package java.rmi.server;
public class Operation {
public Operation(String op);
public String getOperation();
public String toString();
}
构造 Operation 对象时通常带有方法签名。
方法 getOperation 返回操作描述符的内容(其初始化时使用的值)。
方法 toString 也返回操作描述符的字符串表示(通常为方法签名)。
发表评论
-
Java中,对List存放的对象按指定属性排序
2014-06-27 18:15 1015转载的,试用过了,很好! /** * ... -
Interface和抽象类的应用
2012-09-23 19:36 796一个类可以(继承)实 ... -
linux下java开发应掌握的命令
2012-09-23 19:22 1132java开发,由于其很多应用都是发布在Linux操作系统上,因 ... -
Java程序员面试中的多线程问题
2012-06-01 16:55 9260.Java 中多线程同步是什 ... -
Java中的数据存储
2011-11-24 21:31 962在JAVA中,有六个不同的 ... -
Java经典收录,一直更新。。。
2011-11-17 13:45 757Thinking in Java,,敏捷软件开发原则、实践与设 ... -
如何提高Java开发能力
2011-11-15 19:17 14091.你需要精通面向对象 ... -
java.util.ResourceBundle使用详解
2011-08-28 16:32 705一、认识国际化资源文件 这个类提供软件国际化的捷径。通 ... -
抽象类、接口的区别 和 抽象类可以不实现接口的全部方法
2011-07-05 11:05 1040抽象类和接口的区别: ... -
将Unicode字符转换成中文
2011-02-27 13:34 899前段时间写的一个将Unicode字符转换为中文的方法,分享下, ... -
一个Java访问网页时URL重定向的问题
2011-02-25 16:53 3222这是去年年底一直想解决的问题(这么简单的问题,现在才解决,说出 ... -
JAVA虚拟机几个命令行参数说明
2011-02-22 10:13 787一、运行class文件执行带main方法的class文件, ... -
Java数组与容器类分析资料--数组、List和Set、Map
2011-02-22 09:47 1476Java容器分析--数组 数组是Java语言内置的 ... -
常用的 Http Response Code代码
2011-01-11 06:04 895100 Continue 初始的请求已经 ... -
IIS状态代码的含义
2011-01-10 18:59 701概要当用户试图通过HTTP或文件传输协议(FTP)访问一台正在 ... -
Iterator 引发的NoSuchElementException
2011-01-10 15:55 910while (it.hasNext()) { ... -
Firefox的IFrame编程
2010-11-12 10:54 692//最近碰到了很多ie和firefox的js问题,发现主要集 ... -
String和InputStream、Reader 的转换
2010-10-25 08:59 8621、 String --> InputStr ... -
java读取网站内容的两种方法
2010-10-24 19:36 7161,HttpClient利用apache的虚拟客户端包获取某个 ... -
主题:subString方法中的小“陷阱”
2010-10-19 21:19 947今天在工作中遇到一个问题,花了很久才解决,现在与大家分享一下。 ...
相关推荐
JDKTM 6 Documentation Legal Notices API, Language, and ...org.omg.stub.java.rmi org.w3c.dom org.w3c.dom.bootstrap org.w3c.dom.events org.w3c.dom.ls org.xml.sax org.xml.sax.ext org.xml.sax.helpers
2. RMI stub(桩)接收到请求后,会将RMI调用转换为IIOP消息。 3. IIOP消息通过网络发送到服务器端的ORB。 4. 服务器端ORB接收到IIOP消息后,将其转换为对应的语言和ORB特定的调用。 5. 服务器端的Skeleton(骨架)...
4. ** Stub 和 Skeleton**:Stub(代理)是远程接口的本地实现,它负责将本地调用转换为网络消息并发送给服务器。Skeleton(骨架)是服务器端的代理,接收消息并调用相应的远程方法。在现代Java版本中,Stub和...
在Java世界中,远程方法调用(Remote Method Invocation, RMI)是一种机制,它允许一个对象的方法被另一个网络上的对象调用,实现了分布式计算。RMI-IIOP是RMI的一个扩展,它结合了RMI的功能与CORBA的IIOP(Internet...
RMI的核心概念包括远程接口、远程对象和 stub/skeleton。远程接口定义了可以在远程对象上调用的方法,远程对象是实现了这些接口的实体,stub是远程对象的代理,而skeleton则在服务器端处理客户端的调用请求。 其次...
1. **远程接口(Remote Interface)**:这是定义远程方法的接口,它必须继承自java.rmi.Remote接口。每个方法都可能抛出RemoteException,表示网络通信可能出现的问题。 2. **远程对象(Remote Object)**:实现了...
- **代理(Stub)与骨架(Skeleton)**:在RMI中,客户端并不直接与远程对象交互,而是通过本地的代理对象,代理对象将方法调用转换为网络消息发送给服务器。服务器端的骨架对象负责接收这些消息,并调用相应的远程...
【rmi-lite 1.0】是一个轻量级的Java Remote Method Invocation (RMI)实现,它是Java RMI技术的一个简化版本,适用于那些不需要完整RMI功能但仍然希望利用远程对象交互的项目。RMI是Java平台上的一个核心特性,它...
- **JNDI和Stub/Skeleton**:早期的RMI需要Stub和Skeleton,但现在JDK已经自动处理了这些细节,开发者无需手动创建。 4. **安全性**: - RMI支持SSL加密通信,可以通过配置`java.security.policy`文件来设定权限...
这一过程涉及的主要组件包括远程接口、远程对象、注册表和 stub/skeleton 对象。 1. **远程接口(Remote Interface)**:这是定义远程方法的接口,通常继承自Java的`java.rmi.Remote`接口。每个远程方法都可能抛出`...
- ** stub 和 skeleton**: RMI系统会自动生成远程对象的代理(stub)和骨架(skeleton)类,它们是客户端和服务器之间的通信桥梁。 - **注册表**: RMI提供了一个默认的注册表(Registry),用于存储远程对象的引用...
4. ** stub 和 skeleton**:Stub是远程对象在客户端的代理,它实现了远程接口,用于执行客户端的本地调用,并将调用转发到服务器。Skeleton是服务器端的辅助对象,负责接收来自Stub的请求并转发给实际的远程对象。在...
在Java世界中,远程方法调用(Remote Method Invocation, RMI)是一种允许对象在不同的Java虚拟机(JVM)之间进行通信的技术。RMI-IIOP是RMI的一种扩展,它结合了RMI和CORBA(Common Object Request Broker ...
1. **Stub/Skeleton 层:** - Stub 和 Skeleton 层负责处理客户端和服务端之间的网络通信细节。 - Stub 在客户端负责向远程对象发送调用请求,并处理从 Skeleton 返回的结果。 - Skeleton 在服务端负责接收来自 ...
RMI系统的核心概念包括远程接口、远程对象和Stub/Skeleton机制。下面将详细阐述这些知识点。 1. **远程接口**:远程接口是定义远程方法的Java接口。这些接口定义了可以在远程服务器上执行的操作,客户端通过调用...
RMI的核心概念包括客户端、服务端、接口和 stub/skeleton。 **1. RMI 客户端** RMI 客户端是执行远程调用的应用程序。它通过Java的`java.rmi.*`包中的类与服务端建立连接。客户端需要知道服务端的接口(远程接口)...
相对动量指数(RMI)是一种技术分析工具,主要用于金融市场,特别是外汇交易中,以评估资产价格的动量和超买/超卖状态。RMI是相对强弱指数(RSI)的一种演变,旨在通过引入动量概念来提高其预测准确性。在MetaTrader...
spring rmi 2.5.x版本与3.0.x版本不兼容解决方案