Java RMI-IIOP 入门

2016-02-19 13:39 48 1 收藏

关注图老师设计创意栏目可以让大家能更好的了解电脑,知道有关于电脑的更多有趣教程,今天给大家分享Java RMI-IIOP 入门教程,希望对大家能有一点小小的帮助。

【 tulaoshi.com - 编程语言 】

RMI-IIOP出现以前,只有RMI和CORBA两种选择来进行分布式程序设计。RMI-IIOP综合了RMI和CORBA的优点,克服了他们的缺点,使得程序员能更方便的编写分布式程序设计,实现分布式计算。
  
  首先,RMI-IIOP综合了RMI的简单性和CORBA的多语言性(兼容性),其次RMI-IIOP克服了RMI只能用于Java的缺点和CORBA的复杂性(可以不用把握IDL).
  
  下面给出了一个非常的简单的RMI-IIOP程序,该程序是在上一个例子(Java2 RMI入门的基础)上修改完成的,可以对比两个程序的区别。  
  
  1. 实现远程接口,生成远程对象,存根(Stub)和框架(Skeleton)
  
  实现远程接口,远程接口告诉JVM:实现了该接口的对象可以远程调用及有哪些方法可以调用。
  本例子中定义了sayHello()。由于远程调用会涉及到网络通讯,因此这些方法都要抛出RemoteException.
  远程接口和远程对象可以由A开发,并把远程接口(Hello)d打包分给Client端开发者B。 
  
  建立f:
  mi_iiop目录,把Hello.java和HelloImpl.java拷贝到该目录中。
  
  // Hello.java
  package jdeveloper.rmi;
  
  import java.rmi.Remote; 
  import java.rmi.RemoteException; 
  
  public interface Hello extends Remote { 
   String sayHello() throws RemoteException; 
  }
  
  生成远程对象.
  // HelloImpl.java
  package jdeveloper.rmi_iiop;
  
  import javax.naming.*;
  
  import java.rmi.RemoteException;
  import java.rmi.RMISecurityManager;
  //import java.rmi.server.UnicastRemoteObject;
  import javax.rmi.PortableRemoteObject;
  
  public class HelloImpl extends PortableRemoteObject
   implements Hello {
    public HelloImpl() throws RemoteException {
   super();
    }
  
    public String sayHello() {
   return "Hello World!";
    }
  
    public static void main(String args[]) { 
  
    // Create and install a security manager 
   if (System.getSecurityManager() == null) { 
  System.setSecurityManager(new RMISecurityManager()); 
   } 
   try { 
  Hello obj = new HelloImpl(); 
  // Bind this object instance to the name "HelloServer"   
  //***** old code for rmi
  // Naming.rebind("HelloServer", obj); 
  
  //***** new code for rmi-iiop   
  Context initialNamingContext = new InitialContext();   
  initialNamingContext.rebind("HelloServer", obj); 
  
  System.out.println("HelloServer bound in registry"); 
   } catch (Exception e) { 
  System.out.println("HelloImpl err: " + e.getMessage()); 
  e.printStackTrace(); 
   } 
   } 
   }
  
  存根(Stub)和框架(Skeleton)
  f:
  cd 
  mi_iiop
  set classpath=.;%classpath%
  javac -d . Hello.java
  javac -d . HelloImpl.java
  rmic -iiop -d . jdeveloper.rmi_iiop.HelloImpl  
  这一步将生成_Interface>_stub.class,_InterfaceImpl>_Tie.class:
  _Hello_Stub.class和_HelloImpl_Tie.class
  
  
  2. 实现Client端程序
  // HelloClient.java  
   package jdeveloper.rmi_iiop;
  
   import java.rmi.RMISecurityManager;
   import java.rmi.Naming;
   import java.rmi.RemoteException;
   import java.rmi.NotBoundException;
  
   import javax.rmi.PortableRemoteObject;
   import javax.naming.*;
  
   public class HelloClient {
  public static void main(String args[]) throws Exception{  
    System.setSecurityManager(new RMISecurityManager());
    Context initialNamingContext = new InitialContext();
    Hello RemoteObj = (Hello) PortableRemoteObject.narrow(
   initialNamingContext.lookup("iiop://"+ args[0] +"/HelloServer"),
   Hello.class
   );  
    System.out.println(RemoteObj.sayHello());
    }
  }
  
  把HelloClient.java拷贝到目录f:
  mi_iiop中。
  f:
  cd 
  mi_iiop
  javac -d . HelloClient.java
  
  3. 运行程序  
   启动DOS窗口
   运行 tnameserv  
   
   
   把 server.bat 和 policy 放到f:
  mi_iiop  
   启动新的DOS窗口
   运行 server  
   
   
   启动新的DOS窗口
   把 client.bat 放到f:
  mi_iiop   
   运行 client hostname
   
   server.bat
   set CP=%classpath%
   set classpath=.;%classpath%
   java -Djava.naming.factory.initial=com.sun.jndi.cosnaming.CNCtxFactory 
    -Djava.naming.provider.url=iiop://hjc:900 -Djava.security.policy=policy jdeveloper.rmi_iiop.HelloImpl
   set classpath=%CP%
   client.bat
   set CP=%classpath%
   set classpath=.;%classpath%
   java -Djava.naming.factory.initial=com.sun.jndi.cosnaming.CNCtxFactory 
    -Djava.naming.provider.url=iiop://hjc:900 -Djava.security.policy=policy jdeveloper.rmi_iiop.HelloClient %1
   set classpath=%CP%
   policy
   grant {
  // Allow everything for now
  permission java.security.AllPermission;

来源:http://www.tulaoshi.com/n/20160219/1604872.html

延伸阅读
摘要 通过本章的学习,读者能够了解Java出现的历史因素,知道Java语言的优缺点,明白Java语言适合应用于什么领域,对Java语言有一个总体的熟悉。 --------------------------------------------------------------------------- 本章目标: 通过本章的学习,读者能够了解Java出现的历...
1.前言: 当我们学习过了Java中的基本语法,并且熟悉java的面向对象基础以后,我们就可以开始简单的Swing程序的设计,用过Vb的朋友可能会被它的简单的设计用户界面方法所吸引,只需要拖几个控件到窗体上,!-- frame contents -- !-- /frame contents --为每个空件编写event就可以简单的实现界面设计.但是强大的java也不比vb逊色.同样...
如何在win9x下配置JDK 适用于win9x平台下,j2sdk se1.3以上,对j2sdk se1.2.x有一定参考意义! 1总述 1.1什么是JDK JDK是Java develop kit的缩写,它是早期Java的开发包名称,一直延用至今! 在1998年jdk发表1.2版的时候,Sun公司使用了新名称Java 2 platform来称呼Java 译成中文就是“Java平台”,修改后的jd...
Java总有它的千般好处使你选择它,但这些随便翻翻书或在网上逛一圈就能找到答案。在本文中,笔者把自己学习Java的一些切身体会和过程写出来,供初学者做个参考。 我在学习Java的过程中主要围绕以下几个方面来学习: 1.时刻提醒自己Java是一种OOP语言工具,而不仅仅是编码,只有这样才能总体把握和运用Java。 ...
Java 2 Enterprise Edition(J2EE)远程方法调用(Remote Method Invocation,RMI)框架允许你创建透明的、分布式的服务和应用程序。基于RMI的应用程序由Java对象构成,这些对象相互调用,同时忽略对方的位置。换言之,一个Java对象可调用另一个虚拟机上的某个Java对象的方法,整个过程和调用同一个虚拟机上的某个Java对象的方法无异。驻留...

经验教程

576

收藏

32
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部