SOAP 与CORBA,DCOM/COM的比较。
3.1
首先指出的是SOAP不会取代CORBA,COM/DCOM,三者的概念有所区别。COM/DCOM是个组件模型标准,CORBA是分布式应用的服务标
准。CORBA和DCOM为分布式应用程序建立服务,服务对象来执行客户端调用的服务。而SOAP是基于XML和HTTP的分布式对象的通信协议,是
COM/DCOM和CORBA对象进行通讯的协议。实际上,利用SOAP的互操作性和CORBA强大的执行能力,两者可以很好的结合在一起。 OMG
(Object Management Group responsible for the CORBA
specification)正在关注这方面的发展。
3.2. CORBA应用程序和DCOM应用程序不能实现互操作,两者不能在一起协作。因为在ORPC(Object
RPC)协议中,用ObjRef代表了一个正在运行对象的引用;在CORBA/IIOP(Internet Inter-Orb
Protocol)中,用交换可互操作对象引用IOR(Interoperable Object
Reference)代表一个服务器的对象引用。不幸的是,IOR 与
ObjRef不能够关联起来。然而,使用SOAP可以实现在垂直应用层面上CORBA
,DCOM技术的水平整合,能够更好的集成CORBA,DCOM为一个整体。
3.3 SOAP并没有定义信息的语义,服务质量,基于INTERNET的事务处理。而是采用 XML
进行消息编码,正确的处理需要服务器和客户端本身来执行,理解和执行彼此使用的信息格式(ONE-TO-
ONE,REQUEST/REPLY,BROADCAST,ETC),应用程序本身在语义解析中扮演着十分重要的角色。而CORBA,DCOM表示了传送
信息的语义,对参数和返回值使用二进制编码。可对诸如参数名称或类型的任何元信息都不编码,但使中介很难处理消息。又因为每个系统使用不同的二进制编码,
系统间的互操作的很难实现。
3.4
尽管CORBA可以在不同的平台上执行,DCOM可以在微软的各种平台上运行,但是基于CORBA和DCOM的解决方案必须依赖于单一的应用程序。比如
说,假如运行的是DCOM服务器程序,所有的分布式的客户端不得不运行于微软的操作平台上。CORBA
虽然可以运行于不同的平台,但CORBA的互操作性并没有在更高层的服务上进行扩展,如安全性和事务处理,在这种情况下,许多提供的服务没有得到很好的优
化。DCOM和CORBA适合于服务器--服务器间的通讯,但是对于客户端--服务器的通讯十分脆弱,尤其当客户程序分布在INTERNET上更是如此。
3.5
SOAP不象DCOM一样试图定义分布式系统的所有元素,SOAP没有提供分布式类库,类型安全检查,版本控制等等,SOAP比它处于一个更低的层次,有
点类似于IIOP在CORBA的作用,DCOM却提供了一些额外的协议功能,是IIOP 或者SOAP所不具备的。然而,许多.
DCOM的额外功能只有在服务器――服务器间通信时才会用到,对于客户端――服务器之间的通信则是多余的。
相关推荐
SOAP_CORBA及DCOM的分析与比较
### SOAP、CORBA及DCOM的分析与比较 #### 1. 引言 随着信息技术的飞速发展,跨平台、跨语言的分布式系统成为现代企业和组织不可或缺的一部分。分布式系统能够在多个不同的计算环境中协调工作,有效地提高系统的...
SOAP与CORBA和COM/DCOM的区别在于: - **CORBA**:是一种全面的面向对象中间件,提供了一套完整的标准,包括ORB(对象请求代理)、对象服务、公共设施和应用接口。它强调的是对象间的交互,适合大型分布式系统。而...
#### 三、SOAP与CORBA、COM/DCOM的区别? - **CORBA(Common Object Request Broker Architecture)** 是一种面向对象的服务模型,旨在解决分布式对象的互操作性问题。它提供了更为复杂的架构和特性,但同时也增加...
- SOAP与COM/DCOM的主要区别在于SOAP是基于文本的协议,更易于跨平台通信,而COM/DCOM更多地依赖于二进制通信,更适合于Windows内部应用。 #### 六、结论 综上所述,SOAP作为一种基于XML的协议,为解决异构系统间...
与CORBA相比,COM/DCOM更倾向于Windows生态系统,它利用Windows操作系统提供的服务,如注册表和命名管道进行组件的管理和通信。DCOM提供了类似于CORBA的接口概念,但通常更加简化,适合于Windows平台上的快速开发。 ...
SOAP与CORBA(Common Object Request Broker Architecture)和COM/DCOM(Component Object Model / Distributed Component Object Model)的区别在于: - **CORBA** 是一种面向对象的应用程序体系规范,由对象请求...
SOAP与CORBA(Common Object Request Broker Architecture,公共对象请求代理体系结构)和DCOM/COM(Distributed Component Object Model/Component Object Model,分布式组件对象模型/组件对象模型)都是用于实现...
由于传统的RPC方法在跨平台和跨网络环境中的局限性,如DCOM和CORBA等技术在HTTP上的应用存在兼容性问题,且可能被防火墙和代理服务器阻拦,因此SOAP应运而生。SOAP通过HTTP提供了一种标准、安全的通信机制,允许不同...
#### 三、SOAP 与 CORBA、DCOM 的区别 ##### CORBA(Common Object Request Broker Architecture) - 由 OMG 组织制定的标准,面向对象的应用程序体系规范。 - 核心组件是 ORB(Object Request Broker),它提供了...
与传统的分布式计算模型(如CORBA、DCOM、RMI)不同,后者主要通过网络执行远程方法调用;Web服务则侧重于数据的传输,而非直接调用远程方法。 Web服务的一个重要目标是为各种应用程序提供按需使用的软件组件。无论...
SOAP的这一特性吸引了众多软件厂商,如CORBA和COM的供应商承诺支持SOAP协议。同时,DevelopMentor等公司开发了参考实现,使得Java和Perl等语言的开发者能够在任何平台上使用SOAP。此外,SOAP还促进了Web服务的发展,...
随着技术的发展,出现了多种框架实现远程调用,其中包括DCE/RPC、CORBA、DCOM、MTS/COM+、Java RMI、Java EJB、Web Services/SOAP/XML-RPC以及.NET Remoting。本文将深入探讨.NET Remoting的原理与实现,以及其与...
- 随着互联网的普及和技术进步,传统的分布式计算模型如CORBA、DCOM等面临着跨平台性差、配置复杂等问题。 - Web Service作为一种新兴的技术,旨在解决这些问题,通过HTTP协议传输SOAP消息,实现了异构系统的互...
实际的WebService可以是在不同平台上编写的对象或应用程序,如Windows平台上的MTS/COM+或.NET对象,也可以是Linux/UNIX平台上的CORBA或EJB对象。这种架构支持异构系统间的通信,提高了系统的集成能力和互操作性。 #...
#### 五、SOAP与传统RPC协议的对比 - **跨平台性**:SOAP利用HTTP和XML的特性,极大地增强了跨平台的能力。相比之下,如DCOM和CORBA等协议可能受限于特定的操作系统或硬件架构。 - **互操作性**:由于SOAP基于开放...