zoukankan      html  css  js  c++  java
  • Java远程方法调用RMI

            前段时间,公司做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远程调用代码了!运行结果如下:

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

  • 相关阅读:
    Cocos2d-x场景生命周期函数介绍
    一致性hash算法在memcached中的使用
    linux操作系统下查看某rpm包是32bit 还是x64bit的命令
    JavaScript与Java通信
    DevExpress2011控件教程)编辑控件(comboBox,AspxCheckBox) 范例1
    Tips:javascript 图片放大和取得尺寸
    Eclipse颜色主题插件-Eclipse Color Theme
    Android Fragment 详解(一)
    《火球——UML大战需求分析》(第1章 大话UML)——1.4 如何学好UML?
    java.lang.UnsatisfiedLinkError: Native method not found 三种可能解决方案
  • 原文地址:https://www.cnblogs.com/springskyhome/p/3689939.html
Copyright © 2011-2022 走看看