`

<转>JAVA的远程调用

 
阅读更多
原链接:http://blog.csdn.net/fengren01/article/details/6865896
Java 远程处理
   Java远程方法调用(RMI)提供了Java程序语言的远程通讯功能,这种特性使客户机上运行的程序可以调用远程服务器上的对象,使Java编程人员能够在网络环境中分布操作。
   创建一个简单的Java分布式远程方法调用程序可以按以下几个步骤操作,
  
   一、定义远程接口:
   在 Java 中,远程对象是实现远程接口的类的实例, 远程接口声明每个要远程调用的方法。在需要创建一个远程对象的时候,我们通过传递一个接口来隐藏基层的实施细节,客户通过接口句柄发送消息即可。
   远程接口具有如下特点:
   1) 远程接口必须为public属性。如果不这样,除非客户端与远程接口在同一个包内,否则 当试图装入实现该远程接口的远程对象时,调用会得到错误结果。
   2) 远程接口必须扩展接口java.rmi.Remote。
   3) 除与应用程序本身特定的例外之外,远程接口中的每个方法都必须在自己的throws从句中 声明java.rmi.RemoteException。(或 RemoteException 的父类)。
   4) 作为参数或返回值传递的一个远程对象(不管是直接,还是本地对象中嵌入)必须声明为远 程接口,而不应声明为实施类。
   下面是远程接口的接口RmiSample的定义
java 代码
package com.robin.demo.rmi.interf;   
  
import java.rmi.Remote;   
import java.rmi.RemoteException;   
  
public interface RmiSample extends Remote {   
    public int sum(int a, int b) throws RemoteException;   
}   

二、实现远程接口:
   远程对象实现类必须扩展远程对象java.rmi.UnicastRemoteObject类,并实现所定义的远程接口。远程对象的实现类中包含实现每个远程接口所指定的远程方法的代码。这个类也可以含有附加的方法,但客户只能使用远程接口中的方法。因为客户是指向接口的一个句柄,而不是它的哪个类。必须为远程对象定义构造函数,即使只准备定义一个默认构造函数,用它调用基础类构造函数。因为基础类构造函数可能会抛出 java.rmi.RemoteException,所以即使别无它用必须抛出java.rmi.RemoteException例外。
   以下是远程对象实现类的声明:
java 代码
package com.robin.demo.rmi.impl;   
  
import java.rmi.RemoteException;   
import java.rmi.server.UnicastRemoteObject;   
  
import com.robin.demo.rmi.interf.RmiSample;   
  
  
public class RmiSampleImpl extends UnicastRemoteObject implements RmiSample {   
    /**  
     *   
     */  
    private static final long serialVersionUID = 2742977636753958461L;   
  
    public RmiSampleImpl() throws RemoteException {   
        super();   
    }   
  
    public int sum(int a, int b) throws RemoteException {   
        return a + b;   
    }   
  
}   


  
   三、编写服务器类:
   包含 main 方法的类可以是实现类自身,也可以完全是另一个类。下面通过RmiSampleServer 来创建一个远程对象的实例,并通过java.rmi.registry.LocateRegistry类的createRegistry 方法从指定端口号启动注册服务程序,也可以通过执行 rmiregistry 命令启动注册服务程序,注册服务程序的缺省运行端口为 1099。必须将远程对象名字绑定到对远程对象的引用上: Naming.rebind("//localhost:8808/SAMPLE-SERVER" , Server);
   以下是服务器类的声明:
java 代码
package com.robin.demo.rmi.server;   
  
import java.net.MalformedURLException;   
import java.rmi.Naming;   
import java.rmi.RemoteException;   
import java.rmi.registry.LocateRegistry;   
  
import com.robin.demo.rmi.impl.RmiSampleImpl;   
  
  
public class RmiSampleServer {   
  
    /**  
     * @param args  
     */  
    public static void main(String[] args) {   
        try{   
            LocateRegistry.createRegistry(8808);   
            RmiSampleImpl server= new RmiSampleImpl();   
            Naming.rebind("//localhost:8808/SAMPLE-SERVER" , server);   
        }catch (MalformedURLException me){   
            System.out.println("Malformed URL: " + me.toString());   
        }catch(RemoteException re){   
            System.out.println("Remote Exception: "+re.toString());   
        }   
    }   
  
}   


  
   四、编写使用远程服务的客户机类:
   客户机类的主要功能有两个,一是通过Naming.lookup方法来构造注册服务程序 stub 程序实例,二是调用服务器远程对象上的远程方法。
   以下是服务器类的声明:
java 代码
package com.robin.demo.rmi.client;   
  
import java.rmi.Naming;   
import java.rmi.RemoteException;   
  
import com.robin.demo.rmi.interf.RmiSample;   
  
  
public class RmiSampleClient {   
  
    /**  
     * @param args  
     */  
    public static void main(String[] args) {   
        try {   
            String url = "//localhost:8808/SAMPLE-SERVER";   
            RmiSample RmiObject = (RmiSample) Naming.lookup(url);   
            System.out.println(" 1 + 2 = " + RmiObject.sum(1, 2));   
        } catch (RemoteException rex) {   
            System.out.println("Error in lookup: " + rex.toString());   
        } catch (java.net.MalformedURLException me) {   
            System.out.println("Malformed URL: " + me.toString());   
        } catch (java.rmi.NotBoundException ne) {   
            System.out.println("NotBound: " + ne.toString());   
        }   
  
    }   
  
}   


   五、编译代码:
   要编译 Java 源文件,请运行 javac 命令:
   javac RmiSample.java RmiSampleImpl.java RmiSampleServer.java RmiSampleClient.java
  
   六、为远程对象实现创建根和干:
   要创建存根程序和骨架文件,应以包含远程对象实现的已编译类包全名运行 rmic 编译器。
   存根(Stub)是远程对象在客户端的代理,它将RMI调用传递给服务器端的骨架(Skeleton),后者负责将该调用传递给实际的远程方法输入如下:
   D:\RMI>rmic -d D:\RMI RmiSampleImpl 执行这个命令, 若rmic成功运行,RMI目录下就会多出两个新类: RmiSampleImpl_Stub.class RmiSampleImpl_Skel.class 它们分别对应的是存根(stub)和骨架(skeleton).
  
   七、运行代码:
   运行服务端程序:在Windows下,输入下列命令,在后台启动RmiSampleServer程序:
   D:\RMI>java RmiSampleServer
   运行客户端程序:
   D:\RMI>java RmiSampleClient
   客户端输出: 1 + 2 = 3
分享到:
评论

相关推荐

    java远程调用kettle说明与代码

    ### Java远程调用Kettle说明与代码 #### 概述 Kettle是一款强大的开源ETL工具,用于数据清洗和加载。随着数据量的增长以及对数据处理能力的需求提升,分布式执行ETL任务变得越来越重要。Kettle为此提供了名为Carte...

    spring cloud feign实现远程调用服务传输文件的方法

    Spring Cloud Feign 实现远程调用服务传输文件的方法 在微服务架构中,服务之间的调用和文件传输是非常常见的场景。Spring Cloud Feign 是一个基于 Java 的声明式 RESTful 客户端,提供了一种简单、可靠的方式来...

    三种方式实现java远程调用(rmi),绝对可用

    Java远程调用(Remote Method Invocation,RMI)是Java平台中一种重要的分布式计算技术,它允许在不同网络环境中的Java对象之间进行透明的交互。在本文中,我们将深入探讨三种不同的RMI实现方法:原始方式、Spring...

    java应用软件程序设计

    ReadTestquestion&lt;br&gt;7.5. 课程设计作业&lt;br&gt;第8章 日历记事本&lt;br&gt;8.1. 设计内容&lt;br&gt;8.2. 设计要求&lt;br&gt;8.3. 总体设计&lt;br&gt;8.4. 具体设计&lt;br&gt;8.4.1. 运行效果与程序发布&lt;br&gt;8.4.2. 主类CalendarPad&lt;br&gt;8.4.3. 记事本...

    java远程调用kettle说明与代码.docx

    Java 远程调用 Kettle 说明与代码 Kettle 是 Pentaho 数据集成平台中的一个组件,负责执行提取、转换和加载(ETL)任务。Kettle 提供了名为 Carte 的 web 服务器程序,也叫 slave 服务器,启动该程序可以把主机作为...

    用Java实现SOAP的XML文档网络传输及远程过程调用(RPC)

    ### 用Java实现SOAP的XML文档网络传输及远程过程调用(RPC) #### SOAP简介 SOAP(Simple Object Access Protocol,简单对象访问协议)是一种基于XML的协议,它主要用于计算机之间的消息传递,尤其适用于Web服务中...

    TCP-IP技术大全

    TCP/IP和Internet 8&lt;br&gt;2.1 一段历史 8&lt;br&gt;2.1.1 ARPANET 8&lt;br&gt;2.1.2 TCP/IP 9&lt;br&gt;2.1.3 国家科学基金会(NSF) 9&lt;br&gt;2.1.4 当今的Internet 12&lt;br&gt;2.2 RFC和标准化过程 12&lt;br&gt;2.2.1 获得RFC 13&lt;br&gt;2.2.2 RFC索引 13&lt;br...

    java实现远程服务调用

    二、Java实现远程服务调用步骤 1. 添加依赖:首先,你需要在项目的类路径下添加HttpClient的相关依赖。如果你使用的是Maven,可以在pom.xml文件中添加如下依赖: ```xml &lt;dependency&gt; &lt;groupId&gt;org.apache....

    java远程调用kettle说明与代码.pdf

    Java远程调用Kettle说明与代码 Java远程调用Kettle是一种基于Java的ETL(Extract、Transform、Load)工具,能够对数据进行提取、转换、加载,以满足不同业务需求。Kettle提供了名为Carte的Web Server程序,也被称为...

    JAVA RMI远程调用方法代码

    在这个过程中,`getUri`方法用于构造远程对象的URL,通常形式为`rmi://&lt;host&gt;:&lt;port&gt;/&lt;serviceName&gt;`。 ```java MemAccountRead read = (MemAccountRead) Naming.lookup(getUri("rmiObjName")); ``` ### 三、注意...

    基于动态代理的Java远程调用框架的研究1

    Java远程调用框架是分布式系统中关键的技术,它允许运行在不同计算机上的应用程序相互通信,协同完成任务。本文探讨的是一种基于动态代理的Java远程调用框架,旨在解决传统远程调用技术如RMI(Remote Method ...

    service_java接口远程调用_get、post、带参数远程调用_

    - 对于Java接口远程调用,通常会封装成服务类,如`RemoteRequestServiceImpl.java`和`RemoteRequetService.java`中的实现。服务类中会包含执行HTTP请求的方法,可能包括设置请求头、处理响应等逻辑。 4. **使用库...

    akka java实现tcp远程调用

    在Java中,Akka可以用来实现TCP远程调用,这使得不同系统之间能够通过网络进行通信。下面我们将深入探讨如何使用Akka与Java来实现TCP远程调用,以及其中涉及的关键知识点。 首先,我们需要理解Akka的Actor系统。...

    设备在线管理系统源代码

    &lt;br&gt;可完成关键词添加、说明添加,LOGO大小图片添加 &lt;br&gt;管理系统文字友情链接和图片友情链接&lt;br&gt;在线设定多种辅助信息,如使用帮助等&lt;br&gt;系统初始化可方便删除系统数据库中所有数据&lt;br&gt;探测远程服务器,空间查看,...

    java远程调用批处理文件代码归总

    Java远程调用批处理文件是将Java编程与批处理脚本结合的一种技术,它允许Java程序执行在远程服务器上的批处理任务,而无需人工干预。这通常涉及到网络通信和进程间交互,使得分布式系统能够更加灵活地管理和调度任务...

    用Java实现基于SOAP的XML文档网络传输及远程过程调用(RPC)

    ### 用Java实现基于SOAP的XML文档网络传输及远程过程调用(RPC) #### SOAP简介 SOAP(Simple Object Access Protocol,简单对象访问协议)是一种基于XML的协议,用于计算机之间的消息传递与远程过程调用(RPC)。...

    基于java的开发源码-brap(Java远程调用框架 BRAP).zip

    基于java的开发源码-brap(Java远程调用框架 BRAP).zip 基于java的开发源码-brap(Java远程调用框架 BRAP).zip 基于java的开发源码-brap(Java远程调用框架 BRAP).zip 基于java的开发源码-brap(Java远程调用框架 BRAP)....

    java 远程调用工具

    Java远程调用工具是开发过程中不可或缺的利器,尤其在处理分布式系统和服务之间的交互时。本文将深入探讨如何利用Java技术进行远程调用,特别是针对WebService和RESTful接口的调用,以及一个常用的工具——SoapUI。 ...

Global site tag (gtag.js) - Google Analytics