JavaRMI入门教程
介绍
想要java程序成为可调用的远端服务,需要implements(实现)java.rmi.Remote接口即可。javaDOC是这样描述java.rmi.Remote的:
Remote接口哟用于标识方法可以从非本地虚拟机调用。任何物体远程对象必须直接或间接实现此接口。只有在"remote interface"中指定方法,即实现java.rmi.Remote接口,才能实现远程使用。
宗旨
远程方法调用特性使Java编程人员能够在网络环境中分布操作。RMI全部的宗旨就是尽可能简化远程接口对象的使用。
步骤
完成远程调用的步骤如下:
1. 定义一个远程接口,用以实现Remote接口
2. 开发远程接口的实现类
3. 创建一个server,并把远程对象注册到端口
4. 创建一个client查找远程对象,调用远程方法
1.定义远程接口
package rmi; import java.rmi.Remote; public interface IHello extends Remote { public String sayHello(String name) throws java.rmi.RemoteException;
}
2.远程接口实现类
package rmi.impl; import java.rmi.RemoteException; import java.rmi.server.UnicastRemoteObject; import rmi.IHello; public class HelloImpl extends UnicastRemoteObject implements IHello { protected HelloImpl() throws RemoteException { super(); } @Override public String sayHello(String name) throws RemoteException { System.out.println("调用sayHello方法"); return name+"说:hello"; } }
3.创建server,注册对象
package rmi.server; import java.rmi.registry.LocateRegistry; import rmi.IHello; import rmi.impl.HelloImpl; public class HelloServer { public static void main(String[] args) { try { IHello hello = new HelloImpl(); /* 在主机ip上创建并提供一个“注册表”实例,用来接收指明“端口”的请求 */ LocateRegistry.createRegistry(8888); /* 给一个远程对象重新绑定一个“给定”的名字 @param name:必须为一个URI形式 这个方法会覆盖之前已经绑定的名字 */ java.rmi.Naming.rebind("rmi://127.0.0.1:8888/hello", hello); System.out.print("Ready"); } catch (Exception e) { System.out.println("提供远程对象失败,原因是:"+e.getMessage()); } } }
4.创建客户端,请求远程对象
package rmi.client; import java.net.MalformedURLException; import java.rmi.Naming; import java.rmi.NotBoundException; import java.rmi.RemoteException; import rmi.IHello; public class HelloClient { public static void main(String[] args) { try { /* 返回指定名字的远程 对象的一个引用 */ IHello hello = (IHello) Naming.lookup("rmi://127.0.0.1:8888/hello"); System.out.println("调用远程对象,开始交谈:"+hello.sayHello("韩梅梅")); } catch (Exception e) { System.out.println("调用远程对象失败,原因是:"+e.getMessage()); } } }
5.结果
调用远程对象,开始交谈:韩梅梅说:hello