corba编程实例.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
corba编程实例

JavaCORBA编程实例 Java IDL技术在Java平台上添加了CORBA(Common Object Request Broker Architecture)功能,提供了基于标准的互操作能力和连接性。Java IDL技术使得分布式的Java Web应用能够通过使用工业标准的IDL和IIOP(Internet Inter-ORB Protocol)来透明地调用远程网络服务的操作。运行时组件(Runtime Components)包括了一个用于分布式计算且使用IIOP通信的Java ORB. 可移植对象适配器(Portable Object Adapter,POA) CORBA对象的负责分隔服务器端远程调用句柄 (handler)到远程对象和它的服务者(servant)。对象由远程调用所暴露,而服务者包含实际处理这些请求的方法。每个对象都可以选择服务者为 静态的(一次)或动态的(每个远程调用),在这两种情况下,都允许调用转移到另一台服务器。 在服务器端,POA形成了类似树状的结构,每个POA都负责一到多个服务的对象。树的分支可以是独立活动的、或钝化的,服务者调用有不同的代码和不同的请求处理策略。 API规范 ????* org.omg.CORBA 包 - 提供了OMG CORBA APIs到Java编程语言的映射 ????* org.omg.CosNaming 包 - 为Java IDL提供命名服务 ????* org.omg.PortableServer 包 - 为建立服务器端的可移植的、跨越多ORB的应用程序提供类和接口 ????* org.omg.PortableInterceptor 包 - 提供了注册ORB钩子的机制,此钩子通过ORB服务能截取正常的ORB执行流 ????* org.omg.DynamicAny 包 - 提供了使得任何值都能被动态解释(或遍历)和通过DynAny对象构造出来的类和接口 ????* org.omg.CORBA.ORB - 为CORBA ORB功能的API 分布式对象之间的关系有两方面:客户端和服务器。 服务器提供远程接口,客户端调用远程接口。 在客户端,应用程序包括远程对象的引用。该对象引用有stub方法,它是独立的远程方法。stub方法实际连接到ORB,因此调用它实际上转发调用到服务器。 在服务器端,ORB使用skeleton代码翻译远程调用为本地对象的方法调用。Skeleton把调用转换成指定实现的格式,并在方法中调用。当方法返回时,Skeleton代码转换方法调用的结果或错误,经ORB送回客户端。 Java IDL开发过程 1)定义远程接口 使用IDL语言为远程对象定义接口。 【Billing.idl源代码】如下: //?声明CORBA?IDL模块?? module?BillingApp{?? ????//?声明接口?? ????interface?Billing{?? ????????string?successBilling();?? ????????oneway?void?shutdown();?? ????};?? };?? 2)编译远程接口 使用idlj编译器生成Java语言的stub和skeleton源文件。 idlj编译器缺省只生成客户端的binding代码。如果同时需要客户端的bindings和服务器端的skeletons,必须加上-fall选项。 使用POA(Portable Object Adaptor)的优点: · 允许编程者构建对象在不同ORB产品之间的可移植实现 · 支持带持久化标识的对象 · 对对象的透明活动提供支持 · 允许单个servant支持多种对象同时标识 注意:确定jdk/bin目录下有:idlj、java、javac、orbd 命令: ?idlj -fall Billing.idl 在当前目录下生成BillingApp目录,包含如下六个文件: · Billing.java????———— 此接口包含IDL接口的Java版本。它继承自org.omg.CORBA.Object,提供标准的CORBA对象功能。 · BillingHelper.java????———— 此类提供辅助功能,Helper类负责读写数据类型到CORBA流,以及插入和提取数据类型。 · BillingHolder.java????———— This final class holds a public instance member of type Billing. · BillingOperations.java????———— 此接口包含successBilling()和shutdown()方法。 · BillingPOA.java????———— 此抽象类是基于流的

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档