JSP作为客户方访问CORBA服务对象

2008-02-23 08:07:18来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

 结合J2EE和CORBA可以充分利用两者的优点建立性能更好功能更强的应用系统,例如可以使用C 实现的CORBA对象作为业务处理构件,形成高性能业务逻辑层,在JSP中访问CORBA构件建立展现层。 下面我们就一起来看一个在JSP中访问CORBA服务对象的例子。
  软件选择:
  CORBA服务方,我们选择中创软件商用中间件有限公司(http://www.inforbus.com)的InforBus(一个遵循CORBA规范的分布对象中间件),基于C 进行开发。操作系统选择IBM AIX(当然,你也可以选择HP UNIX、Linux或者Windows之类的)。
  CORBA客户方,为了展现CORBA的互操作能力,这里使用了JDK中包含的ORB。当然,作为一种更好的选择,您也可以使用InforBus的Java版本来实现CORBA的客户方。
  JSP运行环境,我们选择中创软件商用中间件有限公司(http://www.inforbus.com)的InforWeb(一个遵循J2EE规范的应用服务器)。操作系统选择Window(当然,你也可以选择HP UNIX、Linux或者AIX之类的)。

  程序实现
  IDL
  IDL是CORBA服务方和客户方进行请求调用的协议,只要使用相同的IDL,客户方和服务方就可以进行无缝的通讯,而与客户方和服务方的开发语言、操作系统都没有关系,甚至你可以为客户方和服务方选择不同的CORBA中间件(只要他们都遵循CORBA规范)。在实现CORBA客户方程序的时候,你不需要关心服务方的任何细节,你所需要关心的只有IDL!
在这里我们定义如下所示的IDL(文件名为apptest.idl):
  1. module example {
  2. interface A {
  3. long AOperation(in long ilData);
  4. };
  5. };


  CORBA服务方程序实现
  CORBA服务方实现需要做的工作主要有:将IDL映射到C ,实现IDL中定义的接口(即实现处理逻辑),编写一个主程序实例化服务对象提供服务。
  1. 将IDL映射到C
  这个只需要调用InforBus的IDL编译器idl,执行如下命令:
idl apptest.idl
  这个命令将产生四个文件:apptest.h、apptest.cpp、apptest_skel.cpp、apptest_skel.cpp,其中包含了Skeleton。
  2. 实现IDL中定义的接口
  继承Skeleton,实现IDL接口定义,在实现类中完成你的业务逻辑,在这个例子中我们实现一个简单的逻辑,将接收到的参数乘以2,然后将结果返回,代码如下:
  1. ////////////////////////////////////////
  2. // 文件名:apptest_impl.h
  3. #ifndef APPTEST_IMPL_H
  4. #define APPTEST_IMPL_H
  5. #include \"apptest_skel.h\"
  6. class A_impl:public POA_example::A, PortableServer::RefCountServantBase {
  7. public:
  8. virtual CORBA::Long AOperation(CORBA::Long ilData)
  9. throw(CORBA::SystemException);
  10. };
  11. #endif
  12. //////////////////////////////////////////////////////
  13. // 文件名:apptest_impl.cpp
  14. // 包含CORBA系统类库
  15. #include <STARCORBA.h>
  16. using namespace std;
  17. #include <apptest_impl.h>
  18. // 操作AOperation的实现
  19. CORBA::Long A_impl::AOperation(CORBA::Long ilData)
  20. throw(CORBA::SystemException) {
  21. CORBA::Long ret;
  22. ret = ilData * 2 ;
  23. return ret;
  24. }


  3. 编写一个主程序实例化服务对象提供服务
  在主程序中,建立CORBA环境,实例化服务对象并注册到名字服务,然后开始等待请求,代码如下(为了):
  1. ///////////////////////////////////////////
  2. // 文件名:Server.cpp
  3. #include <stdio.h>
  4. #include <STARCORBA.h>
  5. #include <STARCosNaming.h>
  6. #include <stdlib.h>
  7. #include <errno.h>
  8. #include \"apptest_impl.h\"
  9. using namespace std;
  10. int main(int argc, char* argv[], char*[]) {
  11. CORBA::ORB_var orb;
  12. orb = CORBA::ORB_init(argc, argv);
  13. CORBA::Object_var nameobj =
  14. orb -> resolve_initial_references(\"NameService\");
  15. CosNaming::NamingContext_var nc =
  16. CosNaming::NamingContext::_narrow(nameobj.in());
  17. CORBA::Object_var poaObj =
  18. orb -> resolve_initial_references(\"RootPOA\");
  19. PortableServer::POA_var rootPOA =

    标签:

    版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Hibernate的缓存机制介绍

下一篇:谈select列表框