Java远程方法调用RMI

fmms 13年前

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

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

     UserDao 接口:

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


UserDaoImpl实现类

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


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

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

 

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

 

/**   * 远程方法调用测试   * @author spring sky   * date:2012年2月7日 11:12:46   * Email:vipa1888@163.com   * QQ:840950105   * name:石明政   */  public class TestRemote {   public static void main(String[] args) {    try {     //在rmi服务中查询userdao的对象     UserDao userDao = (UserDao) Naming.lookup("rmi://127.0.0.1:9999/userDao");        //调用远程服务的方法     userDao.sayName("spring sky");    } catch (MalformedURLException e) {     System.err.println("URL出错");     e.printStackTrace();    } catch (RemoteException e) {     System.err.println("远程对象出错");     e.printStackTrace();    } catch (NotBoundException e) {     System.err.println("没有找到绑定的对象");     e.printStackTrace();    }   }  }

 

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

0_1328585803as7n.gif.jpg

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

 来自:http://blog.csdn.net/vipa1888/article/details/7238800