捷凌网安JAVA频道
捷凌IT教育
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME 开源技术 其他技术 论坛
 您现在的位置: 捷凌网安 >> Java >> J2EE >> RmiCorbaJini >> 正文
Apusic应用服务器和CORBA互操作

作者:佚名 责任编辑:左决 点击数: 更新时间:2008-3-24 15:51:24

 CORBA(Common Object Request Broker ArchITecture, 公共对象请求代理体系结构)是由OMG(对象管理组织,Object Management Group)提出的应用软件体系结构和对象技术规范,被广泛的用来开发分布式系统。Apusic应用服务器是以RMI-IIOP(Remote Method Invocation Internet Inter-ORB Protocol)协议为基础完成分布式的对象的远程访问,因此可以和CORBA对象进行互相调用。并且,Apusic应用服务器还完整的实现了CORBA-EJB映射规范,能够在多个应用服务器实例和CORBA客户端之间传播事务、安全等上下文信息。CORBA和EJB的互操作规范包含以下四个方面:

  EJB接口到CORBA接口的映射;

  JNDI名字到CORBA名称服务(CosNaming )的映射;

  EJB和CORBA之间的事务传播;

  EJB和CORBA之间的安全传播。

  本文将通过一个范例展示CORBA客户端访问部署在Apusic上的EJB。虽然这是Apusic和CORBA互操作最简单的一个方面,并且不涉及安全和事务的传播,但已经显示了Apusic在互操作方面的能力和开发的一般步骤。

  首先介绍一下服务器和客户端的开发运行环境。服务器端的环境为:

  Windows 2000 Server

  JDK1.4.2

  Apusic应用服务器3.0

  客户端的环境为:

  Windows 2000 Professional

  JDK1.4.2

  Apusic应用服务器完全支持标准的EJB-CORBA映射,也就是说,EJB的home和remote也是CORBA对象。我们可以使用JDK提供的RMI编译器rmic -idl为EJB产生CORBA视图的IDL接口。用来定位EJB home接口的JNDI(java naming service)被映射成CORBA naming service,这样,CORBA客户端就能查找和定位home接口并象CORBA对象一样使用它们。下图描述了CORBA客户端访问EJB的一般步骤:这些步骤包括:

  开发并部署EJB;

  使用RMI编译器rmic -idl为EJB远程接口产生IDL;

  使用CORBA IDL编译器根据客户端的程序语言为客户端产生存根(stub);

  配置EJB服务器使用CORBA名称服务。Apusic缺省就使用CORBA名称服务作为JNDI 服务的提供者;

  CORBA客户端在CORBA名称服务中查找和定位EJB;

  CORBA客户端象访问普通CORBA对象一样访问EJB;

  首先开发一个EJB模块,编译并部署到Apusic应用服务器上。这个例子中的EJB非常简单,是一个Stateless Session Bean,只包含一个业务方法sayHello。

  public java.lang.String sayHello(java.lang.String name) {

  String result = "hello, " + name;

  System.out.println("invoke sayHello() : " + result);

  return result;

  }

  然后使用RMI编译器rmic -idl为EJB远程接口产生IDL:

  rmic -idl -noValueMethods

  -classpath %apusic_home%/lib/apusic.jar;../ejb/build

  -d idl samples.ejb.Hello samples.ejb.HelloHome

  理论上可以使用任何CORBA规范支持的程序语言开发CORBA客户端。本范例展示的是java CORBA客户端的开发。使用JDK1.4.2提供的idlj编译上一步得到的IDL:

  idlj -emITAll -i ./idl -i %java_home%/lib

  -fclient

  -pkgPrefix java apusic

  -pkgPrefix javax apusic

  -pkgPrefix samples apusic

  -td src

  ./idl/samples/ejb/Hello.idl

  idlj -emITAll -i ./idl -i %java_home%/lib

  -fclient

  -pkgPrefix java apusic

  -pkgPrefix javax apusic

  -pkgPrefix samples apusic

  -td src

  ./idl/samples/ejb/HelloHome.idl

  注意,我们为IDL文件中的java、javax和samples模块在生成代码时增加了“apusic”作为package的前缀,这样可以避免同java核心API的冲突。

  JDK1.4.2提供的idlj编译器生成的Java代码包含了bug,必须手工更改这些错误。将类_Exception.java,CreateException.java和RemoveException.java中的_read和 _wrITe方法注释或删掉。

  这时,我们根据IDL编译器编译生成的java文件,提供客户端实现,主程序的代码片断如下:

  ORB orb = ORB.inIT(args, null);

  // Look up the HelloHome, create an Hello and use IT.

  NamingContextExt nc =

  NamingContextExtHelper.narrow(orb.resolve_inITial_references("NameService"));

  HelloHome home =

  HelloHomeHelper.narrow(nc.resolve_str("ejb/CORBAClientSample"));

  Hello hello = home.create();

  String str = (String) hello.sayHello("apusic,corba client");

  System.out.println(str);

  System.exIT(0);

  从上面的代码中我们看到了CORBA客户端如何在CORBA名称服务中查找和定位EJB,并且如何象访问普通CORBA对象一样访问EJB。

  最后我们编译并运行客户端。注意,我们并不需要编译所有idlj生成的Java源文件,只要编译包apusic.sample.ejb和我们编写的客户端主程序。java编译器会根据类的连接情况自动编译类中引用的其他类。

  javac -d ../build -sourcepath ./ apusic\samples\ejb\*.java

  javac -d ../build -sourcepath ./ CorbaClient.java

  确认EJB已经部署在Apusic上并且服务器正常运行。在命令行启动CORBA客户端,通过启动参数告诉客户端Apusic的位置和端口,来保证客户端ORB的正确初始化。假定Apusic运行在本机上,端口为6888:

  java CorbaClient -ORBInitialHost localhost -ORBInITialPort 6888

  如果前面的步骤都正确完成,我们将在客户端的屏幕上看到: hello, apusic,corba client

  这个例子只是简单的展示了CORBA客户端能够访问EJB组件的业务方法。实际上CORBA和EJB的互操作复杂的地方在于事务和安全的映射,因此要求开发者对CORBA规范和开发比较熟悉。而且java到IDL的映射可能遇到很多问题,例如:ValueType映射,集合的使用等,这就使CORBA客户端访问EJB在很多情况下不能成功。即使如此,Apusic支持和CORBA的互操作,依然对我们集成已有的CORBA系统、开发异构环境的分布式应用提供了很大的帮助,只是对开发人员的技术要求比较高。
  • 上一篇文章:

  • 下一篇文章:
  •  
     最进更新
    普通文章J2SE实现windows读取网卡的物05-11
    普通文章Scala—Java的避难所之main(05-11
    普通文章Spring数据源的灵活配置巧应05-11
    普通文章Spring 与 Log4J 进行动态日05-11
    普通文章Heritrix的多线程ToeThread和05-11
    普通文章应用spring示例开发网站构思05-11
    普通文章Spring 数据源配置与应用05-11
    普通文章Spring中的四种声明式事务的05-11
    普通文章Hibernate+Spring搞定Clob、05-11
    普通文章Hibernate的映射关联关系05-11
     
     推荐文章
    推荐文章Java技术开源搜索引擎04-30
    推荐文章Eclipse中建立自己的JUnit测04-30
    推荐文章Eclipse 3.3上安装jadclipse04-30
    推荐文章spring 编程入门十大问题解答04-30
    推荐文章Java编程中Spring的一些负面04-30
    推荐文章Java应用中Hibernate对多表关04-30
    推荐文章关于hibernate的缓存和CRUD04-30
    推荐文章基于Struts1.2的动态多文件上04-30
    推荐文章演示Struts2实现简单上传代码04-30
    推荐文章J2EE学习笔记--Struts初步认04-30
     
     热点文章
    普通文章J2SE实现windows读取网卡的物05-11
    普通文章Scala—Java的避难所之main(05-11
    普通文章Spring数据源的灵活配置巧应05-11
    普通文章Spring 与 Log4J 进行动态日05-11
    普通文章Heritrix的多线程ToeThread和05-11
    普通文章应用spring示例开发网站构思05-11
    普通文章Spring 数据源配置与应用05-11
    普通文章Spring中的四种声明式事务的05-11
    普通文章Hibernate+Spring搞定Clob、05-11
    普通文章Hibernate的映射关联关系05-11

    | 设为首页 | 加入收藏 | 联系站长 | 广告服务 | 友情链接 | 版权申明 | 网站地图 |

    在线交流 捷凌网安主群:51649627
    Copyright 2007-2008 © 捷凌网安. All rights reserved.
    备案序号:蜀ICP备08001812号