Java远程方法调用RMI

前段时间,公司做web service的时候,看了一下资料,当时看见一个叫rmi的东西(远程方法调用),最近闲着,所以看了一下 ,感觉挺简单的!所以写了一个例子提供给大家把!

  rmi的服务端,必须要使用接口,同时还有接口的实现类!所以下面的两个文件是接口类和接口的实现类!

  UserDao 接口:

  1. /** 
  2.  * 远程接口     必须继承与Remote对象 
  3.  * @author spring sky 
  4.  * date: 2012年2月7日 10:55:05 
  5.  * Email:vipa1888@163.com 
  6.  * QQ:840950105 
  7.  */ 
  8. public interface UserDao extends Remote{  
  9.     /** 
  10.      * 简单的测试方法 
  11.      * @param name 
  12.      */ 
  13.     public void sayName(String name) throws RemoteException;   
  14. }

  UserDaoImpl实现类

  1. /** 
  2.  *  
  3.  *  接口的实现类    必须继承UnicastRemoteObject(单一远程对象)   实现UserDao自己的接口 
  4.  * @author spring sky 
  5.  * date: 2012年2月7日 10:56:05 
  6.  * Email:vipa1888@163.com 
  7.  * QQ:840950105 
  8.  */ 
  9. public class UserDaoImpl extends UnicastRemoteObject implements UserDao {  
  10.     public UserDaoImpl() throws RemoteException {  
  11.     }  
  12.     @Override 
  13.     public void sayName(String name) {  
  14.         if(name!=null&&!name.equals(""))  
  15.         {  
  16.             System.out.println("我的名字是:"+name);  
  17.         }else{  
  18.             System.err.println("名字不为空....");  
  19.         }  
  20.     }  
  21. }

  对外的提供一个服务,服务中已经共享了url给外界访问

  1. /** 
  2.  * 使用main方法启动一个服务,用于外界环境访问 
  3.  * @author spring sky 
  4.  * date:2012年2月7日 10:57:37 
  5.  * Email:vipa1888@163.com 
  6.  * QQ:840950105 
  7.  */ 
  8. public class StartService {  
  9.     private static final String IP = "127.0.0.1";  
  10.     private static final int PORT = 9999;  
  11.     private static final String REMOTE_NAME = "userDao";  
  12.     private static final String REMOTE_URL = "rmi://"+IP+":"+PORT+"/"+REMOTE_NAME;  
  13.     public static void main(String[] args) {  
  14.         try {  
  15.             UserDao userDao = new UserDaoImpl();    //实例化对象 
  16.             LocateRegistry.createRegistry(PORT);    //注册端口 
  17.             Naming.bind(REMOTE_URL, userDao);       //绑定远程服务对象 
  18.             System.out.println("远程"+REMOTE_NAME+"启动成功....");  
  19.         } catch (RemoteException e) {  
  20.             System.err.println("远程对象出错");  
  21.             e.printStackTrace();  
  22.         } catch (MalformedURLException e) {  
  23.             System.err.println("URL出错了");  
  24.             e.printStackTrace();  
  25.         } catch (AlreadyBoundException e) {  
  26.             System.err.println("绑定的对象已经存在了");  
  27.             e.printStackTrace();  
  28.         }  
  29.     }  
  30. }

上面是服务端的代码,如果启动没有任何问题,就可以做客户端访问了,其实客户端的访问更加的简单,只需要远程的接口类和查询rmi中的url就可以了!

  代码如下:

  1. /**  
  2.  * 远程方法调用测试  
  3.  * @author spring sky  
  4.  * date:2012年2月7日 11:12:46  
  5.  * Email:vipa1888@163.com  
  6.  * QQ:840950105  
  7.  * name:石明政  
  8.  */ 
  9. public class TestRemote {  
  10.     public static void main(String[] args) {  
  11.         try {  
  12.             //在rmi服务中查询userdao的对象  
  13.             UserDao userDao = (UserDao) Naming.lookup("rmi://127.0.0.1:9999/userDao");     
  14.             //调用远程服务的方法  
  15.             userDao.sayName("spring sky");  
  16.         } catch (MalformedURLException e) {  
  17.             System.err.println("URL出错");  
  18.             e.printStackTrace();  
  19.         } catch (RemoteException e) {  
  20.             System.err.println("远程对象出错");  
  21.             e.printStackTrace();  
  22.         } catch (NotBoundException e) {  
  23.             System.err.println("没有找到绑定的对象");  
  24.             e.printStackTrace();  
  25.         }  
  26.     }  
  27. }

  以上就是所有的rmi远程调用代码了!运行结果如下:

Java远程方法调用RMI

  好了,本人也只是简单的了解了rmi,如果以后有项目做rmi就可以深入了! 呵呵  ,在这里我突然感觉,想web service也应该和他一样的原理的把!

 


本文出自seven的测试人生公众号最新内容请见作者的GitHub页:http://qaseven.github.io/

上一篇:Ubuntu下使用VI编辑文件必知的常用命令


下一篇:Oracle11g卸载详解