RMI 远程调用_JAVA_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > JAVA > RMI 远程调用

RMI 远程调用

 2013/8/1 22:10:13  laodaobazi  程序员俱乐部  我要评论(0)
  • 摘要:服务端接口类:packagecom.demo.rmi.server;importjava.rmi.Remote;importjava.rmi.RemoteException;importjava.util.Map;/***定义一个远程接口,必须继承Remote接口,其中需要远程调用的方法必须抛出RemoteException异常*/publicinterfaceIHelloextendsRemote{/***@return对象Map*@throwsjava.rmi
  • 标签:远程

服务端接口类:

class="java">package com.demo.rmi.server;

import java.rmi.Remote;
import java.rmi.RemoteException;
import java.util.Map;

/**
* 定义一个远程接口,必须继承Remote接口,其中需要远程调用的方法必须抛出RemoteException异常
*/
public interface IHello extends Remote {

    /**
     * @return 对象 Map
     * @throws java.rmi.RemoteException
     */
    public Map<String,String> helloWorld() throws RemoteException;

    /**
     * 一个简单的业务方法,根据传入的人名返回相应的问候语
     * @param someBodyName  人名
     * @return 返回相应的问候语
     * @throws java.rmi.RemoteException
     */
    public String sayHello(String someBodyName) throws RemoteException;
}

?接口类的实现:

package com.demo.rmi.server;

import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
import java.util.HashMap;
import java.util.Map;

/**
* 远程的接口的实现
*/
public class HelloImpl extends UnicastRemoteObject implements IHello {

	private static final long serialVersionUID = -302768834288959127L;

	/**
     * 因为UnicastRemoteObject的构造方法抛出了RemoteException异常,因此这里默认的构造方法必须写,必须声明抛出RemoteException异常
     *
     * @throws RemoteException
     */
    public HelloImpl() throws RemoteException {
    }

    /**
     * @return 对象 Map
     * @throws java.rmi.RemoteException
     */
    public Map<String,String> helloWorld() throws RemoteException {
    	Map<String,String> map = new HashMap<String,String>();
    	map.put("key", "Hello World!");
        return map;
    }

    /**
     * 一个简单的业务方法,根据传入的人名返回相应的问候语
     *
     * @param someBody
     * @return 返回相应的问候语
     * @throws java.rmi.RemoteException
     */
    public String sayHello(String someBody) throws RemoteException {
        return "你好," + someBody + "!";
    }
}

?

服务端发布RMI服务:

package com.demo.rmi.server;

import java.net.MalformedURLException;
import java.rmi.AlreadyBoundException;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;

/**
* 创建RMI注册表,启动RMI服务,并将远程对象注册到RMI注册表中。
*/
public class HelloServer {
	
    public static void main(String args[]) {

        try {
            //创建一个远程对象
            IHello rhello = new HelloImpl();
            //本地主机上的远程对象注册表Registry的实例,并指定端口为8888,这一步必不可少(Java默认端口是1099),必不可缺的一步,缺少注册表创建,则无法绑定对象到远程注册表上
            LocateRegistry.createRegistry(8888);

            //把远程对象注册到RMI注册服务器上,并命名为RHello
            //绑定的URL标准格式为:rmi://host:port/name(其中协议名可以省略,下面两种写法都是正确的)
            Naming.bind("rmi://localhost:8888/RHello",rhello);

            System.out.println(">>>>>INFO:远程IHello对象绑定成功!");
        } catch (RemoteException e) {
            System.out.println("创建远程对象发生异常!");
            e.printStackTrace();
        } catch (AlreadyBoundException e) {
            System.out.println("发生重复绑定对象异常!");
            e.printStackTrace();
        } catch (MalformedURLException e) {
            System.out.println("发生URL畸形异常!");
            e.printStackTrace();
        }
    }
}

?

?

?

客户端代码调用:

package com.demo.rmi.client;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;

import com.demo.rmi.server.IHello;

/**
* 客户端测试,在客户端调用远程对象上的远程方法,并返回结果。
*/
public class HelloClient {
    public static void main(String args[]){
        try {
            //在RMI服务注册表中查找名称为RHello的对象,并调用其上的方法
            IHello rhello =(IHello) Naming.lookup("rmi://localhost:8888/RHello");
            System.out.println(rhello.helloWorld());
            System.out.println(rhello.sayHello("Java"));
        } catch (NotBoundException e) {
            e.printStackTrace();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (RemoteException e) {
            e.printStackTrace();  
        }
    }
}

?

?

事例代码已经上传。

?

  • rmi.rar (6.8 KB)
  • 下载次数: 0
发表评论
用户名: 匿名