JavaRMI-IIOP入门

王朝java/jsp·作者佚名  2008-05-19
宽屏版  字体: |||超大  

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;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有