创建接口
/** * 定义一个远程接口,必须继承Remote接口 */public interface HelloService extends Remote{ /** * 需要远程调用的方法必须抛出RemoteException异常 * @param msg * @return * @throws RemoteException */ String sayHello(String msg) throws RemoteException;}
2.创建实现类
/** * 远程的接口的实现. */public class HelloServiceImpl extends UnicastRemoteObject implements HelloService{ /** * 因为UnicastRemoteObject的构造方法抛出了RemoteException异常, * 因此这里默认的构造方法必须写,必须声明抛出RemoteException异常 * @throws RemoteException */ public HelloServiceImpl() throws RemoteException { } /** * 业务实现方法 * @param msg * @return * @throws RemoteException */ public String sayHello(String msg) throws RemoteException { return "server received the msg : " + msg; }}
3.创建启动服务
/** * 创建RMI注册表, * 启动RMI服务, * 并将远程对象注册到RMI注册表中。 */public class HelloServer{ public static void main(String[] args) { try { //创建一个远程对象 HelloService helloService = new HelloServiceImpl(); //本地主机上的远程对象注册表Registry的实例,并指定端口为8888. // 这一步必不可少(Java默认端口是1099),必不可缺的一步. // 缺少注册表创建,则无法绑定对象到远程注册表上 LocateRegistry.createRegistry(9123); //把远程对象注册到RMI注册服务器上,并命名为hello //绑定的URL标准格式为:rmi://host:port/name(其中协议名可以省略) Naming.bind("rmi://localhost:9123/hello", helloService); System.err.println("==========远程对象绑定成功============"); } catch (RemoteException e) { System.err.println("创建远程对象发生异常!"); e.printStackTrace(); } catch (MalformedURLException e) { System.out.println("发生URL畸形异常!"); e.printStackTrace(); } catch (AlreadyBoundException e) { System.out.println("发生重复绑定对象异常!"); e.printStackTrace(); } }}
4.创建客户端
/** * 在客户端调用远程对象上的远程方法 */public class HelloClient{ public static void main(String[] args) { try { //在RMI服务注册表中查找名称为helloService的对象,并调用其上的方法 HelloService helloService =(HelloService) Naming.lookup("rmi://localhost:9123/hello"); System.out.println(helloService.sayHello("测试")); } catch (NotBoundException e) { e.printStackTrace(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (RemoteException e) { e.printStackTrace(); } }}
注:RMI要求服务端和客户端的编写语言都是java.如果需要跨语言,则建议使用webservice.
参考地址:http://docs.oracle.com/javase/6/docs/technotes/guides/rmi/hello/hello-world.html