- 浏览: 1205335 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (718)
- HTML (13)
- JS基础 (23)
- JS应用 (40)
- AJAX (6)
- JSP相关 (12)
- JAVA基础 (52)
- JAVA应用 (74)
- APPLET (11)
- SWING\RCP (2)
- JAVA反射 (6)
- 设计模式 (26)
- 数据库设计 (20)
- Struts (35)
- Struts2 (12)
- Spring (22)
- Hibernate (45)
- Ibatis (18)
- mybatis (3)
- SSH (8)
- UML (5)
- WebService (3)
- XML (16)
- Log4j (7)
- WEB容器 (26)
- 数据结构 (36)
- Linux (34)
- Ruby on Rails (1)
- 其它技术 (27)
- IDE配置 (15)
- 项目实战 (2)
- Oracle (69)
- JAVA报表 (7)
- Android学习 (2)
- 博客链接 (1)
- 网络基础 (1)
- WEB集群 (1)
- .Net开发 (11)
- PB (4)
- 系统构建 (15)
最新评论
-
jnjeC:
牛逼啊哥们,讲得太好了
Maven仓库理解、如何引入本地包、Maven多种方式打可执行jar包 -
九尾狐的yi巴:
很好 感谢!
Itext中文处理(更新版) -
luweifeng1983:
有用的,重启一下嘛。
设置eclipse外部修改文件后自动刷新 -
Master-Gao:
设置了也不管用,怎么破呢?
设置eclipse外部修改文件后自动刷新 -
aigo_h:
锋子还有时间写博客,还是很闲哈!
Add directory entries问题
RMI软件下载:http://www.genady.net/rmi/v20/demos/
注意下载对应eclipse版本的RMI插件:http://www.genady.net/rmi/v20/downloads.html
因为如果插件版本与eclipse不一样可能会报以下错误:
Unable to use launch shortcut Reason: Plug-in net.genady.rmi was unable to load class net.genady.rmi.launching.ui.RMIServerLaunchShortcut. org/eclipse/jdt/debug/ui/launchConfigurations/JavaApplicationLaunchShortcut
Demo查看:http://www.genady.net/rmi/v20/demos/
对着这个demo一步步操作就会得到三个项目。注意demo中的操作。
先看一下RMI基本原理:
结合实例看一下RMI开发的主要步骤:
一个正常工作的RMI系统由下面几个部分组成: • 远程服务的接口定义 • 远程服务接口的具体实现 • Stub 和 Skeleton 文件 • 一个运行远程服务的服务器 • 一个RMI命名服务,它允许客户端去发现这个远程服务 • 类文件的提供者(一个HTTP或者FTP服务器) • 一个需要这个远程服务的客户端程序
1、编写并且编译接口的Java代码 2、编写并且编译接口实现的Java代码 3、从接口实现类中生成 Stub 和 Skeleton 类文件 4、编写远程服务的主运行程序 5、编写RMI的客户端程序 6、安装并且运行RMI系统
类图如下:
具体构建步骤可以看:http://www.genady.net/rmi/v20/demos/分别创建接口文件,接口的实现文件;以及服务端文件,客户端代码;
再运行注册服务器,最后运行服务端代码,再运行客户端代码看是否成功调用服务端方法。
附件中有rmi相关文章及示例代码。
下面太概列一下自己的步骤方便查看:
首先安装eclipse的rmi插件,下载对应eclipse版本的rmi插件。:
建立公共项目,里面就只有一个接口文件,因为服务端和客户端都要用到,所以建立这个公共项目了。
项目名:print-common
文件:RemotePrinter .java
package demo.rmi.print.common; import java.rmi.Remote; import java.rmi.RemoteException; public interface RemotePrinter extends Remote { public String add(String str1, String str2) throws RemoteException; }
下面建立服务端项目:
项目名:print-server
接口实现类:RemotePrinterImpl.java
package demo.rmi.print.server; import java.rmi.RemoteException; import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; import java.rmi.server.UnicastRemoteObject; import demo.rmi.print.common.RemotePrinter; public class RemotePrinterImpl extends UnicastRemoteObject implements RemotePrinter { public RemotePrinterImpl() throws RemoteException{ } @Override public String add(String str1, String str2) throws RemoteException { System.out.print("add method has een called"); return str1 + str2; } }
注意接口实现类继承了UnicastRemoteObject 类,需要定义构造方法并抛出异常。
在服务端新建类PrintServer.java用于启动服务,绑定方法。
package demo.rmi.print.server; import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; public class PrintServer { /** * @param args */ public static void main(String[] args) { try{ Registry r = LocateRegistry.getRegistry(); r.bind("printer", new RemotePrinterImpl()); System.out.println("printer server is ready"); }catch(Exception e){ e.printStackTrace(); } } }
完了之后重要的一步:右键点击项目print-server找到RMI里面点Enable Stubs Gerneration,这样在编译后的文件夹目录会多出一个RemotePrinterImpl_Stub.class;
右键点击项目print-server找到Properties,点RMI Compiler Properties.勾选-keep选项,在源代码目录产生RemotePrinterImpl_Stub.java类。此类使用代理模式运用反射机制生成。
下面新建项目print-client
客户端类:PrintClient.java
package demo.rmi.print.client; import java.rmi.Naming; import java.rmi.RMISecurityManager; import demo.rmi.print.common.RemotePrinter; public class PrintClient { /** * @param args */ public static void main(String[] args) { try{ System.setSecurityManager(new RMISecurityManager()); RemotePrinter printer = (RemotePrinter)Naming.lookup("rmi://localhost/printer"); String str = printer.add("good", "str2"); System.out.println(str); }catch(Exception e){ e.printStackTrace(); } } }
注意使用了System.setSecurityManager(new RMISecurityManager());
好了。代码就这么多。如何运行?
1、先运行eclipse工具栏的rmi的start local registry
2、运行PrintServer.java,对该文件点右键Run as RMI Application,可以打开dialog,找到RMI VM Properties
在java.rmi.server.codebase,选择后点compute from classpath,得到相应内容后确定,run
3、运行客户端,PrintClient.java,对该文件点右键Run as RMI Application,可以打开dialog,找到RMI VM Properties在java.security.policy后面选择点create,确认后会在print-client项目下生成 security.policy文件点OK,RUN后打印出goodstr2,结果表明调用了服务器端的方法。远程调用成功。
上面写的是用RMI插件编码产生stub和Skel类文件,用过一段时间之后发现插件过期了,不行那怎么办呢?能不能手动编译呢?参考以下链接:
如何使用RMI:http://download.oracle.com/javase/1.5.0/docs/guide/rmi/hello/hello-world.html
如何编译生成文件:http://download.oracle.com/javase/1.5.0/docs/tooldocs/windows/rmic.html
编译方法:cmd控制台进入src目录,使用命令:rmic -g -keep -vcompat com.customs.GateServer
编译后产生了GateServer_Skel.class,GateServer_Skel.java,GateServer_Stub.class,GateServer_Stub.java文件。
发表评论
-
JAVA短信发送及JAVA发送http请求与处理
2016-06-22 14:34 516JAVA发送HTTP请求与处理参考: http://ww ... -
Java Zip应用
2016-06-22 14:30 541应用系统中使用jdk原生 ... -
模拟tomcat进行http请求及响应处理:BufferedReader类的readLine在socket网络编程应用时发生阻塞
2016-05-11 15:04 1656最近写一个简单的程序模拟tomcat进行http请求及响应 ... -
Castor-xml映射出现节点重复问题解决
2015-08-13 16:24 1178最近在使用Castor-xml生成XML时发现生成的格式不 ... -
Add directory entries问题
2014-08-05 10:24 1835用spring注解的项目,eclipse可以运行,打成jar ... -
BeanUtils.copyProperties与PropertyUtils.copyProperties用法及区别
2013-01-25 16:21 855http://www.cnblogs.com/fayf/ar ... -
java.net.BindException: Cannot assign requested address
2012-06-13 14:10 863转:http://wgkgood.blog.51cto ... -
Duplicate name in Manifest: Depends-On
2012-06-13 13:13 1609解决方法:http://ww2.sjc.edu/faculty ... -
java tree
2011-11-16 02:01 1263import java.util.ArrayList; im ... -
jacob操作word和excel
2011-07-28 17:00 867http://danadler.com/jacob/ -
获得PrepareStatement 的最终执行语句
2011-07-04 10:07 976方法一:http://www.blogjava.net/ ... -
Non-terminating decimal expansion; no exact representable decimal result
2011-06-24 16:03 2576由于需要处理精度比较高的浮点数,所以弃用double类型,改用 ... -
JXLS应用示例
2011-06-03 01:41 3412JXLS在循环的记录前加序号: <jx:f ... -
月份加减方法处理
2011-06-03 00:52 891private static String monthAdd ... -
JAVA 5.0 后 自带监控工具 jps、jinfo、jstat、jma
2011-05-12 16:25 1216最近有个客户要进行WebLogic性能调优,但因为他们没有性能 ... -
定时器的实现、java定时器介绍与Spring中定时器的配置
2011-04-28 15:05 25051定时器的作用 在实际的开发中,如果项目中需要定时执行或者需 ... -
ClientAbortException,Connection reset by peer: socket write error
2011-03-07 11:24 6030extremetable导出excel,弹出一个下载窗口,这 ... -
java 调ireport (javaBean数据源)保存服务器 生成word
2011-02-24 14:40 1515package com.ztesoft.bidding.con ... -
JAVA包生成EXE应用实例
2011-01-06 15:35 1002相关文章:http://blog.csdn.net/fresh ... -
JAVA jar打包时MANIFEST.MF格式约定
2010-12-10 11:12 2196Manifest-Version: 1.0 Created-B ...
相关推荐
NULL 博文链接:https://skyandcity.iteye.com/blog/1547028
用JAVA程序实现RMI,实现客户端和服务器间的时间同步,并计算出两端的时间差
源代码 博文链接:https://forchase.iteye.com/blog/1454428
其根据一个简单示例来说明。。rmi 客户端,和远程服务器端
RMI是Remote Method Invocation(远程方法调用)的 所写。它允许一个Java程序调用网络中另一台计算机上的Java方法,...实现RMI调用的程序和被调用的方法,都必须是Java代码,即客户端和服务器端都必须通过纯Java实现。
远程调用使得调用远程服务器的对象、方法的方式就和调用本地对象、方法的方式差不多,因为我们通过网络编程把这些都隐藏起来了。远程调用是分布式系统的基础。 远程调用一般分为两种,远程过程调用(RPC)和远程方法...
RMI跨平台调用的demo,客户端运行在Windows,服务器端运行在linux,测试通过
rmi 成功实例。两个工程的远程调用。RMIServer是服务器端,RMIClient是客户端。创建两个工程,先开启服务器端。如是在两台机子上实验,请把客户端的请求ip改到你要连接的服务器的ip。
它使客户机上运行的程序可以调用远程服务器上的对象。远程方法调用特性使Java编程人员能够在网络环境中分布操作。RMI全部的宗旨是尽可能简化远程接口对象的使用。 Java RMI极大地依赖于接口。在需要创建一个远程...
Java 远程方法调用 (Java RMI) 是一个 Java API,它执行远程过程调用 (RPC) 的面向对象等价物,支持序列化 Java 类的直接传输和分布式垃圾收集。 远程过程调用:消息传递远程过程调用 (RPC) 是一种允许程序调用位于...
它使客户机上运行的程序可以调用远程服务器上的对象。远程方法调用特性使Java编程人员能够在网络环境中分布操作。RMI全部的宗旨就是尽可能简化远程接口对象的使用。 Java RMI极大地依赖于接口。在需要创建一个远程...
RMI.js是一些JavaScript客户端代码和Node.js模块的组合,该模块可以实现远程方法的隐式调用。 开发人员可以使用本地,远程或两者的方法定义对象,然后在客户端上调用它们。 框架将知道实现是存储在本地还是在服务器...
从客户端调用要在服务器上执行的远程方法(RMI)。 服务器上的序列化( Marshalling )向客户端发送响应。 客户端接收响应并本地执行。 RMI的第二节是为了更好地理解RMI的Marshalling(对象序列化),在继续之前完成...
RMI远程方法调用,简单,资源少 CORBA 通用对象请求代理架构,IIOP 协议中的二进制数据交换 RMI-IIOP 远程方法调用 - Internet Inter-Ojbect 协议,结合 RMI 和 CORBA 的优势 COM+ 公共对象模型 SOAP 简单对象访问...
使用客户端指定的代码库调用远程方法(远程类加载攻击) 使用ysererial小工具或客户端指定的代码库执行DGC和注册表调用 对rmi注册表执行bind , unbind和rebind操作 使用绕过注册表筛选 枚举java.lang.String的解组...
RMI远方法程调用步骤:客户调用客户端辅助对象stub上的方法客户端辅助对象stub打包调用信息(变量,方法名),通过网络发送给服务端辅助对象骨架服务端辅助对象骨架将客户端辅助对象发送来的信息解包,找出真正被...
从客户端调用要在服务器上执行的远程方法(RMI) 服务器上的序列化( Marshalling )向客户端发送响应 客户端接收响应并本地执行 内容 在开始之前 推荐工具: 蚀 Java 1.6 或更高版本。 面向对象编程的中级知识。 ...