SOAP is a messaging protocol specification for exchanging structured information in the implementation of web services in computer networks . It uses XML Information Set for its message format , and relies on application layer protocols, most often Hypertext Transfer Protocol (HTTP), although some legacy systems communicate over Simple Mail Transfer Protocol (SMTP), for message negotiation and transmission.
14-484: SOAP provides the Messaging Protocol layer of a web services protocol stack for web services. It is an XML-based protocol consisting of three parts: SOAP has three major characteristics: As an example of what SOAP procedures can do, an application can send a SOAP request to a server that has web services enabled—such as a real-estate price database—with the parameters for a search. The server then returns
28-444: A SOAP response (an XML-formatted document) with the resulting data, e.g., prices, location, features. Since the generated data comes in a standardized machine-parsable format, the requesting application can then integrate it directly. The SOAP architecture consists of several layers of specifications for: SOAP evolved as a successor of XML-RPC , though it borrows its transport and interaction neutrality from Web Service Addressing and
42-499: A more complex set of web services , based on WSDL , XSD and UDDI . These different services, especially UDDI, have proved to be of far less interest, but an appreciation of them gives a complete understanding of the expected role of SOAP compared to how web services have actually evolved. SOAP specification can be broadly defined to be consisting of the following three conceptual components: protocol concepts, encapsulation concepts and network concepts. The SOAP specification defines
56-405: A range of higher-level protocols such as Business Process Execution Language (WS-BPEL) or WS-Security for security extensions. This computer networking article is a stub . You can help Misplaced Pages by expanding it . This article related to telecommunications is a stub . You can help Misplaced Pages by expanding it . SOAP-over-UDP SOAP-over-UDP is an OASIS standard covering
70-533: A specific application. The drawback is that both the senders and receivers have to support this newly defined binding. The message below requests a stock price for AT&T (stock ticker symbol "T"). Web services protocol stack A web service protocol stack is a protocol stack (a stack of computer networking protocols ) that is used to define, locate, implement, and make Web services interact with each other. A web service protocol stack typically stacks four protocols: The protocol stack can also include
84-480: Is the same protocol as HTTP at the application level, but uses an encrypted transport protocol underneath) with either simple or mutual authentication; this is the advocated WS-I method to provide web service security as stated in the WS-I Basic Profile 1.1. This is a major advantage over other distributed protocols like GIOP/IIOP or DCOM , which are normally filtered by firewalls. SOAP over AMQP
98-472: Is yet another possibility that some implementations support. SOAP also has an advantage over DCOM that it is unaffected by security rights configured on the machines that require knowledge of both transmitting and receiving nodes. This lets SOAP be loosely coupled in a way that is not possible with DCOM . There is also the SOAP-over-UDP OASIS standard. XML Information Set was chosen as
112-474: The envelope/header/body from elsewhere (probably from WDDX ). SOAP was designed as an object-access protocol and released as XML-RPC in June 1998 as part of Frontier 5.1 by Dave Winer , Don Box , Bob Atkinson, and Mohsen Al-Ghosein for Microsoft , where Atkinson and Al-Ghosein were working. The specification was not made available until it was submitted to IETF 13 September 1999. According to Don Box, this
126-404: The messaging framework, which consists of: A SOAP message is an ordinary XML document containing the following elements: Both SMTP and HTTP are valid application layer protocols used as transport for SOAP, but HTTP has gained wider acceptance as it works well with today's internet infrastructure; specifically, HTTP works well with network firewalls . SOAP may also be used over HTTPS (which
140-423: The other hand, hardware appliances are available to accelerate processing of XML messages. Binary XML is also being explored as a means for streamlining the throughput requirements of XML. XML messages by their self-documenting nature usually have more 'overhead' (e.g., headers, nested tags, delimiters) than actual data in contrast to earlier protocols where the overhead was usually a relatively small percentage of
154-514: The overall message. In financial messaging SOAP was found to result in a 2–4 times larger message than previous protocols FIX (Financial Information Exchange) and CDR (Common Data Representation). XML Information Set does not have to be serialized in XML. For instance, CSV and JSON XML-infoset representations exist. There is also no need to specify a generic transformation framework. The concept of SOAP bindings allows for specific bindings for
SECTION 10
#1732802112318168-568: The specification, however, became a W3C recommendation on June 24, 2003. SOAP originally stood for "Simple Object Access Protocol" but version 1.2 of the standard dropped this acronym. The SOAP specification was maintained by the XML Protocol Working Group of the World Wide Web Consortium until the group was closed 10 July 2009. After SOAP was first introduced, it became the underlying layer of
182-616: The standard message format because of its widespread use by major corporations and open source development efforts. Typically, XML Information Set is serialized as XML . A wide variety of freely available tools significantly eases the transition to a SOAP-based implementation. The somewhat lengthy syntax of XML can be both a benefit and a drawback. While it facilitates error detection and avoids interoperability problems such as byte-order ( endianness ), it can slow processing speed and can be cumbersome. For example, CORBA , GIOP , ICE , and DCOM use much shorter, binary message formats. On
196-487: Was due to politics within Microsoft. Because of Microsoft's hesitation, Dave Winer shipped XML-RPC in 1998. The submitted Internet Draft did not reach RFC status and is therefore not considered a "web standard" as such. Version 1.1 of the specification was published as a W3C Note on 8 May 2000. Since version 1.1 did not reach W3C Recommendation status, it can not be considered a "web standard" either. Version 1.2 of
#317682