Java远程方法调用RMI

开发 后端
前段时间,公司做web service的时候,看了一下资料,当时看见一个叫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.  
  15.  

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.  
  11.     public UserDaoImpl() throws RemoteException {  
  12.     }  
  13.     @Override 
  14.     public void sayName(String name) {  
  15.         if(name!=null&&!name.equals(""))  
  16.         {  
  17.             System.out.println("我的名字是:"+name);  
  18.         }else{  
  19.             System.err.println("名字不为空....");  
  20.         }  
  21.     }  
  22.  

对外的提供一个服务,服务中已经共享了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.     }  

上面是服务端的代码,如果启动没有任何问题,就可以做客户端访问了,其实客户端的访问更加的简单,只需要远程的接口类和查询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.     }  

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

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

原文链接:http://blog.csdn.net/vipa1888/article/details/7238800

【编辑推荐】

  1. Java处理字符串搜索嵌套结构的方法
  2. Java编程:常见问题汇总
  3. Java迷题:等于,还是不等于?
  4. Java数据库连接代码集合
  5. Java编程语言的认识误区
责任编辑:林师授 来源: vipa1888的博客
相关推荐

2012-04-11 11:10:25

JavaRMI

2019-06-21 14:48:25

RMI远程RPC

2018-02-28 14:04:08

RMIJDBC存储

2014-09-02 10:43:45

RedisRPC

2021-05-11 00:08:00

JavaRMI 分布式

2011-03-28 10:42:00

Spring

2022-09-15 07:31:49

Spring拦截器注解

2016-04-21 10:10:31

Java应用架构

2010-07-19 14:08:15

2009-12-08 17:15:43

PHP调用Java语言

2012-05-29 15:17:08

JavaWMIC

2009-06-17 13:19:50

Java调用DLL

2010-08-25 17:08:18

实例教程

2013-05-29 09:59:20

Java-RMI远程调用

2012-03-01 13:34:02

Java

2021-07-26 17:28:03

Java开发代码

2011-08-29 09:54:45

LUAJAVA 方法

2009-06-19 14:23:41

RMIJava分布式计算

2010-10-29 16:12:51

Oracle存储过程

2009-08-11 11:07:49

Java调用C# we
点赞
收藏

51CTO技术栈公众号