首页 > 代码库 > 远程调用之RMI技术
远程调用之RMI技术
---恢复内容开始---
RMI已经不是什么新的技术了,但是相对于webservice来说,rmi比较简单,比较适合一些小的应用,下面的helloword列子可以介绍rmi的相关技术
服务器端代码:
服务器接口实现Remote
1 package com.qcf.server; 2 3 import java.rmi.Remote; 4 import java.rmi.RemoteException; 5 /** 6 * 服务类 7 * 定义行为集 8 * @author Administrator 9 *10 */11 public interface IHello extends Remote {12 13 //在服务器端打印客户端传过来的字符串并返回该字符串14 public String sayHello(String str) throws RemoteException;15 }
接口的实现类
1 package com.qcf.server; 2 3 import java.rmi.RemoteException; 4 import java.rmi.server.UnicastRemoteObject; 5 6 /** 7 * 服务器端实现类 8 * 需要继承UnicastRemoteObject 9 * @author Administrator10 *11 */12 public class IHelloImpl extends UnicastRemoteObject implements IHello{13 14 //必须的15 protected IHelloImpl() throws RemoteException {16 super();17 }18 19 @Override20 public String sayHello(String str) throws RemoteException {21 System.out.println("客户端传过来的字符串是:" + str);22 return str;23 }24 25 }
服务类启动服务类
1 package com.qcf.server; 2 3 import java.net.MalformedURLException; 4 import java.rmi.AlreadyBoundException; 5 import java.rmi.Naming; 6 import java.rmi.RemoteException; 7 import java.rmi.registry.LocateRegistry; 8 9 /**10 * RMI服务器11 * 1、创建一个服务12 * 2、启动服务器13 * 3、注册服务14 * @author Administrator15 *16 */17 public class HelloServer {18 19 public static void main(String[] args) throws RemoteException, MalformedURLException, AlreadyBoundException {20 //1、创建一个服务21 IHello iHello=new IHelloImpl();22 //2、启动服务器 启动一个注册表并把注册表绑定到一个端口(默认端口1099) 23 LocateRegistry.createRegistry(8189);24 25 //3将服务注册到注册表 绑定的URL标准格式为:rmi://host:port/name(其中协议名可以省略,下面两种写法都是正确的) 26 Naming.bind("rmi://localhost:8189/ihello", iHello);27 System.out.println("server start success!");28 }29 }
客户端类
创建接口类如上
客户端测试类
1 package com.qcf.client; 2 3 import java.net.MalformedURLException; 4 import java.rmi.Naming; 5 import java.rmi.NotBoundException; 6 import java.rmi.RemoteException; 7 8 /** 9 * 客户端测试类10 * 服务器是谁 服务器11 * 如何获取服务 查找12 * 调用接口13 * @author Administrator14 *15 */16 public class HelloClient {17 public static void main(String[] args) throws Exception, Exception, Exception {18 //查找服务19 IHello hello=(IHello) Naming.lookup("rmi://localhost:8489/ihello");20 //调用接口21 String str=hello.sayHello("哈哈哈 。我测试成功了");22 System.out.println("客户端"+str);23 }24 }
运行RMI服务端程序:
运行RMI客户端程序:
总结:
从上面的过程来看,RMI对服务器的IP地址和端口依赖很紧密,但是在开发的时候不知道将来的服务器IP和端口如何,但是客户端程序依赖这个IP和端口。
这也是RMI的局限性之一。这个问题有两种解决途径:一是通过DNS来解决,二是通过封装将IP暴露到程序代码之外。
RMI的局限性之二是RMI是Java语言的远程调用,两端的程序语言必须是Java实现,对于不同语言间的通讯可以考虑用Web Service或者公用对象请求代理体系(CORBA)来实现。
---恢复内容结束---
远程调用之RMI技术
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。