Name

Marshal — Marshals data into a specified format for transmission over a transport or component

Usage

The Marshal pattern uses Apache Camel's pluggable data format mechanism to convert messages into a format appropriate for transmission by one of the Apache Camel components.

The Marshal pattern can be placed anywhere in the body of a route. However, it is typically placed before endpoints that transmit the message to another location.

Properties

Table 51 describes the properties you can specify using the properties editor.

Table 51. Marshal Properties

NameDescription
Data Format Type

Specifies the data type into which the data will be marshalled. For data formats that require configuration, the format's tab provides the property fields to configure the marshaller.

Because the GZip, Serialization, String, and Zip data formats are part of the Camel core, you need not add dependencies for them in your Maven pom.xml file to use them. However, to use any of the other supported data formats, you must add a dependency on the component that implements the data format (for example, camel-protobuf, camel-xmlbeans, camel-flatpack, and so on) in your Maven pom.xml file.

  • bindy— Marshals Java Objects into flat data structures

  • castor—Marshals Java Objects to XML

  • crypto—Marshals Java Objects to encrypted cyphertext

  • csv—Marshals Java Objects to csv format

  • custom—Marshals Java Objects to a custom data format implemented using the DataFormat interface

  • flatpack—Marshals Java Objects to fixed-width or delimited text messages

  • gzip—Marshals normal, uncompressed messages to gzipped compressed messages

  • hl7—Marshals HL7 HAPI message objects to byte streams

  • jaxb—Marshals Java Objects to XML

  • jibx—Marshals Java Objects to XML using the JiBX library

  • json—Marshals Java Objects to JSON

  • pgp—Marshals Java Objects to encrypted cyphertext

  • protobuf—Marshals Java Objects to Protocol Buffers format (Google's data exchange format)

  • rss—Marshals ROME SyndFeed messages to XML String messages

  • secureXML—Marshals plain XML to encrypted XML. This data format works at the document, element, and element content levels.

  • serialization—Marshals Java Objects to a binary blob using the standard Java serialization mechanism

  • soapjaxb—Marshals a tree of Java Objects to a SOAP message using JAXB and JAX-WS annotations

  • string—Marshals XML or text-based messages to String Objects

  • syslog—Marshals Java String Objects to RFC3164 message format

  • xmlbeans—Marshals Java objects to XML using the XmlBeans library

  • xstream—Marshals Java objects to XML using the XStream library

  • zip—Marshals normal, uncompressed messages to zipped compressed messages

RefSpecifies a reference to a Spring bean configuring the Apache Camel data format to which the message body is marshalled.
IdSpecifies a unique identifier for the endpoint. The Id can be used to refer to the endpoint in the Camel XML file.
DescriptionSpecifies a text description for the node. This description is included in the generated XML file, but it is informational only. It is not used by Apache Camel.

bindy

Table 52 describes the properties needed to configure the bindy marshaller.

Table 52. bindy Properties

NameDescription
Class Type

Specifies a fully qualified class name that explicitly defines the type to use for marshalling. For example, you might enter com.mycompany.MyOrder

You must use either this property or Packages, but not both.

Locale

Species the language name of the locale whose date and number format will be used. If not specified, the marshaller determines and uses the formatting of a default language name. Valid values are the two-letter abbreviation of the language name, in lower case. For example,

  • ar—Arabic

  • es—Castilian Spanish

  • da—Danish

  • en—English

  • fr—French

  • jp—Japanese

For an exhaustive list of language names, see Codes for the Representation of Names of Languages

Packages

Specifies the packages to use for marshalling. A package contains a defined model with required annotations properly associated for each class in the model. For example, you might enter com.mycompany.

When specifying multiple packages, separate them with a comma (,).

You must use either this property or Class Type, but not both.

TypeSpecifies the record type, Select either Csv (comma-separated value fields), Fixed (fixed-length records), or KeyValue (key/value pair fields).

castor

Table 53 describes the properties needed to configure the castor marshaller.

Table 53. castor Properties

NameDescription
ClassesSpecifies additional classes to add to the Castor XmlContext. Enter the fully qualified path. When specifying multiple classes, separate them with a comma (,).
EncodingSpecifies the encoding to use when marshalling an Object to XML. Default is UTF-8.
Mapping FileSpecifies the path to the Castor mapping file to load from the classpath.
PackagesSpecifies any additional packages to add to the Castor XmlContext. Enter the fully qualified path. When specifying multiple classes, separate them with a comma (,).

crypto

Table 54 describes the properties needed to configure the crypto marshaller.

Table 54. crypto Properties

NameDescription
AlgorithmSpecifies the name of the JCE cryptographic algorithm to use. Default is DES/CBC/PKCS5Padding.
Algorithm Parameter RefSpecifies a reference to the JCE AlgorithmParameterSpec to use to initialize the cipher. Some crypto algorithms, particularly block algorithms, require initialization by an initial block of data, known as an Initialization Vector. The JCE passes the Initialization Vector to the cipher as an AlgorithmParameterSpec . Select from the list of available options.
BuffersizeSpecifies the size, in bytes, of the buffer used in the signature process.
Crypto ProviderSpecifies the name of the JCE Security Provider to use. For options, see Java Cryptography Architecture; Sun Providers Documentation.
Init Vector RefSpecifies a reference to a byte array containing the Initialization Vector to use to initialize the cipher. Select from the list of available options.
InlineEnables inlining the configured Initialization Vector into the encrypted data stream.
Key RefSpecifies the value of the keyref attribute within the <dataFormats> element in a Spring configuration. For example, <crypto id="basic" algorithm="DES" keyref="desKey" />. Select from the list of available options.
Mac AlgorithmSpecifies the algorithm to use to create the Hash-based Message Authentication. Default is HmacSHA1. For more options, see Java Standard Names Reference.
Should Append HMACEnables calculating and appending a Message Authentication Code to the encrypted data.

csv

Table 55 describes the properties needed to configure the csv marshaller.

Table 55. csv Properties

NameDescription
DelimiterSpecifies the character to use to separate the fields in a csv record. Default is , (comma). Valid values are any single character, such as ., |, ;, #, and so on.

custom

Table 56 describes the properties needed to configure the custom marshaller.

Table 56. custom Properties

NameDescription
RefReference to file that implements your custom data format using the DataFormat interface.

jaxb

Table 57 describes the properties needed to configure the jaxb marshaller.

Table 57. jaxb Properties

NameDescription
Context PathSpecifies the context path for the jaxb data format. For example, org.apache.camel.example
Encoding

Specifies the encoding to use when marshalling data. Valid values include:

  • ISO-8859-1

  • US-ASCII

  • UTF-8

With no value specified, Fuse IDE defaults to the encoding used by JAXB.

Filter Non XML CharsEnables the filtering of non XML characters during marshalling such that the marshaller replaces any non XML characters it encounters with the string " ". Otherwise, when it encounters a non XML character, the marshaller throws an exception.
FragmentEnables the marshaller's FRAGMENT encoding property, which prevents the marshaller from generating the XML declaration. Enable this property in conjunction with setting Part Class and Part Namespace to perform partial marshalling on only a fragment of the XML tree.
Ignore JAXBElementNot Applicable.
Part ClassSpecifies the uri of the class within the XML tree that you want to marshal, leaving all other classes in the tree as is. Set this property in conjunction with Fragment and Part Namespace to perform partial marshalling on only a fragment of the XML tree.
Part NamespaceSpecifies the Qname of the destination namespace.
Pretty PrintEnables pretty printing, which adds white space as needed to tidy up the resulting XML for easy reading.

json

Table 58 describes the properties needed to configure the json marshaller.

Table 58. json Properties

NameDescription
LibrarySpecifies the library to use for marshalling. Select either XStream or Jackson from the drop-down list. Default is XStream.
Pretty PrintEnables pretty printing, which adds white space as needed to tidy up the resulting XML for easy reading.
Unmarshal Type NameNot Applicable.

pgp

Table 59 describes the properties needed to configure the pgp marshaller.

Table 59. pgp Properties

NameDescription
ArmoredSpecifies whether to base64 encode the encrypted text, so it can be copied/pasted, and so on. The default is Disabled.
IntegritySpecifies whether to add an integrity check sign to the encrypted file. The default is Enabled.
Key File NameSpecifies the name of the keyring file that contains the public keys to use to encrypt the data. This file must be accessible as classpathresource; for example, org/apache/camel/component/crypto/pubring.gpg.
Key User IdSpecifies the user id of the key in the pgp keyring used for encryption.
PasswordSpecifies the password to use for opening the private key. This password is not used for encryption.

protobuf

Table 60 describes the properties needed to configure the protobuf marshaller.

Table 60. protobuf Properties

NameDescription
Instance ClassSpecifies the name of the instance class to use for marshalling. This is one of the classes generated when you compiled your .proto file. Include the builder generated in the uri; for example, org.apache.camel.dataformat.protobuf.generated.<nameOfInstanceClass>.

secureXML

Table 61 describes the properties needed to configure the secureXML marshaller.

Table 61. secureXML Properties

NameDescription
Key Cipher Algorithm[a]

Specifies the cipher algorithm to use to encrypt the asymmetric key. Default is null. Valid values are:

  • XMLCipher.RSA_v1dot5

  • XMLCipher.RSA_OAEP

Asymmetric key encryption is enabled when either this property is set, or the Recipient Key Alias property is set.

Key Or Trust Store Parameters Id[a]Specifies the ID of the configuration options to use to create and load a keyStore instance that represents the sender's trustStore, when performing asymmetric key encryption.
Pass PhraseSpecifies a string of alphanumeric characters to use as the passphrase for marshalling the message into cyphertext. The passphrase must be appropriate for the selected encryption algorithm. if not, the marshaller throws an exception. When no phrase is specified, the marshaller generates and uses a default passphrase.
Recipient Key Alias[a]Specifies the key alias to use for retrieving the recipient's public or private key from a KeyStore when performing asymmetric key encryption.
Secure TagSpecifies the XPath reference to the XML element to encrypt. If left blank, the entire XML message is encrypted.
XML Cipher Algorithm

Specifies the cipher algorithm to use for encrypting message content. Valid values include:

  • XMLCipher.TRIPLIDES [Default]

  • XMLCipher.AES_128

  • XMLCipher.AES_192

  • XMLCipher.AES_256

[a] Used for asymmetric key encryption


soapjaxb

Table 62 describes the properties needed to configure the soapjaxb marshaller.

Table 62. soapjaxb Properties

NameDescription
Context PathSpecifies the path of the package to use for initializing the JAXB context.
Element Name Strategy RefSpecifies the bean reference to use to the element name and its namespace within the body of the soap message. Select for the list of available options.
Encoding

Specifies the encoding to use when marshalling data. Valid values include:

  • ISO-8859-1

  • US-ASCII

  • UTF-8

With no value specified, Fuse IDE defaults to the encoding used by JAXB.


string

Table 63 describes the properties needed to configure the string marshaller.

Table 63. string Properties

NameDescription
Charset

Specifies the character set to use for encoding. Valid values include:

  • ISO-8859-1

  • US-ASCII

  • UTF-8

With no value specified, Fuse IDE defaults to the encoding used by the platform.


XmlBeans

Table 64 describes the properties needed to configure the XmlBeans marshaller.

Table 64. XmlBeans Properties

NameDescription
Pretty PrintEnables pretty printing, which adds white space as needed to tidy up the resulting XML for easy reading.

zip

Table 65 describes the properties needed to configure the zip marshaller.

Table 65. zip Properties

NameDescription
Compression Level

Specifies the level of compression for the marshaller to use. When no value is specified, the marshaller uses its default compression algorithm. Valid values are:

  • deflater.BEST_SPEED

    Conservative compression, optimized for speed.

  • deflater.BEST_COMPRESSION

    Aggressive compression, slowest speed.

  • deflater.DEFAULT_COMPRESSION

    Moderate compression, moderate speed.


Related topics

Adding beans and configuration