Jump to content

XML-binary Optimized Packaging: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
TobbiM (talk | contribs)
Added w3c navigationbar
m Remove stub template(s). Page is start class or higher. Also check for and do General Fixes + Checkwiki fixes using AWB
Line 31: Line 31:
==Usage in SOAP Web services==
==Usage in SOAP Web services==


The MIME packaging mechanism is the most widely used, since XOP is usually used to represent [[SOAP]] messages with [[Message_Transmission_Optimization_Mechanism|MTOM]].
The MIME packaging mechanism is the most widely used, since XOP is usually used to represent [[SOAP]] messages with [[Message Transmission Optimization Mechanism|MTOM]].


For example:
For example:
Line 60: Line 60:
==See also==
==See also==


*[[Message_Transmission_Optimization_Mechanism|MTOM]] (Message Transmission Optimization Mechanism)
*[[Message Transmission Optimization Mechanism|MTOM]] (Message Transmission Optimization Mechanism)


==References==
==References==
Line 69: Line 69:
==External links==
==External links==
*[http://www.w3.org/TR/xop10/ W3C's XML-binary Optimized Packaging] W3C Recommendation
*[http://www.w3.org/TR/xop10/ W3C's XML-binary Optimized Packaging] W3C Recommendation

{{W3C standards}}


[[Category:XML-based standards]]
[[Category:XML-based standards]]
{{Markup-languages-stub}}{{W3C standards}}

Revision as of 17:10, 13 December 2013

XML-binary Optimized Packaging (XOP) is a mechanism defined for the serialization of XML Information Sets that contain binary data, as well as deserialization back into the XML Information Set.

Benefits

XOP allows the binary data part of an XML Infoset to be serialized without going through the XML serializer. The XML serialization of an XML Infoset is text based, so any binary data will need to be encoded using base64. Using XOP avoids this by extracting the binary data out of the XML Infoset so that the XML Infoset does not contain binary data and the binary data can be serialized differently.

Therefore, XOP can reduce the size of the serialization (since base64 encoding has approximately a 33% size overhead) and (depending on how it is implemented) might allow processing efficiencies. This size increase results in extra resources needed to transmit or store the data.

Costs

XOP introduces another level of processing. Therefore, it introduces extra complexity and processing overheads.

The representation of the XOP packages introduces some overhead. These are negligible when the binary data is large, but could be significant if the binary data is small.

Operation

XOP operates on a single XML Infoset.

The binary parts of the original XML infoset are extracted out, leaving an "XOP Infoset" (which is essentially the original XML Infoset with the binary parts replaced by external references). The references in the XOP Infoset are represented using the "xop:Include" element. The XOP Infoset plus the extracted content can be serialized into a representation called the "XOP Package". The XOP Package can be sent or stored.

To reconstitute the XML Infoset, the XOP Package is deserialized into the XOP Infoset plus the extracted content, and then the extracted content is put back into the XML Infoset.

XOP Packages

XOP can be used with a number of different packaging mechanisms. A packaging mechanism defines how the XOP Infoset and the binary chunks are represented.

The XOP specification defines how MIME can be used as a packaging mechanism. When used with MIME, the XOP Infoset is represented as XML in the root MIME part, and the binary chunks are represented in the other MIME parts. Those other MIME parts can be serialized as binary data, avoiding the need to base64 encode them if they were left inside the XML Infoset.

XOP does not mandate the use of the MIME packaging mechanism, so other packaging mechanisms could be used.

Usage in SOAP Web services

The MIME packaging mechanism is the most widely used, since XOP is usually used to represent SOAP messages with MTOM.

For example:

 MIME-Version: 1.0
 Content-Type: Multipart/Related;boundary=MIME_boundary;
 ...
 --MIME_boundary
 Content-Type: application/xop+xml; 
 ...

 <soap:Envelope ...
  <soap:Body>...
      <m:photo xmlmime:contentType='image/png'>
        <xop:Include xmlns:xop='http://www.w3.org/2004/08/xop/include' 
           href='cid:http://example.org/me.png'/></m:photo>
 ...

 --MIME_boundary
 Content-Type: image/png
 Content-Transfer-Encoding: binary
 Content-ID: <http://example.org/me.png>

 // binary octets for png

See also

  • MTOM (Message Transmission Optimization Mechanism)

References