Java RMI-IIOP 入门

jdeveloper

       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;  
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值