Base64

Since Camel 2.11

The Base64 data format is used for base64 encoding and decoding.

Options

The Base64 dataformat supports 3 options, which are listed below.

Name Default Java Type Description

lineLength (common)

76

Integer

To specific a maximum line length for the encoded data. By default 76 is used.

lineSeparator (advanced)

String

The line separators to use. By default \r\n is used.

urlSafe (advanced)

false

Boolean

Instead of emitting and / we emit - and _ respectively. urlSafe is only applied to encode operations. Decoding seamlessly handles both modes.

In Spring DSL, you configure the data format using this tag:

XML-only: Spring XML data format configuration
<camelContext>
    <dataFormats>
        <!-- for a newline character (\n), use the HTML entity notation coupled with the ASCII code. -->
        <base64 lineSeparator="&#10;" id="base64withNewLine" />
        <base64 lineLength="64" id="base64withLineLength64" />
    </dataFormats>
    ...
</camelContext>

Then you can use it later by its reference:

  • Java

  • XML

  • YAML

from("direct:startEncode")
    .marshal("base64withLineLength64")
    .to("mock:result");
<route>
     <from uri="direct:startEncode" />
     <marshal ref="base64withLineLength64" />
     <to uri="mock:result" />
</route>
- route:
    from:
      uri: direct:startEncode
      steps:
        - marshal:
            ref: base64withLineLength64
        - to:
            uri: mock:result

Most of the time, you won’t need to declare the data format if you use the default options. In that case, you can declare the data format inline as shown below.

Marshal

In this example, we marshal the file content to a base64 object.

  • Java

  • XML

  • YAML

from("file://data.bin")
    .marshal().base64()
    .to("jms://myqueue");
<route>
  <from uri="file://data.bin"/>
  <marshal>
    <base64/>
  </marshal>
  <to uri="jms://myqueue"/>
</route>
- route:
    from:
      uri: file://data.bin
      steps:
        - marshal:
            base64: {}
        - to:
            uri: jms://myqueue

Unmarshal

In this example, we unmarshal the payload from the JMS queue to a byte[] object, before its processed by the newOrder processor.

  • Java

  • XML

  • YAML

from("jms://queue/order")
    .unmarshal().base64()
    .process("newOrder");
<route>
  <from uri="jms://queue/order"/>
  <unmarshal>
    <base64/>
  </unmarshal>
  <to uri="bean:newOrder"/>
</route>
- route:
    from:
      uri: jms://queue/order
      steps:
        - unmarshal:
            base64: {}
        - to:
            uri: bean:newOrder

Dependencies

To use Base64 in your Camel routes, you need to add a dependency on camel-base64 which implements this data format.

If you use Maven, you can add the following to your pom.xml:

<dependency>
  <groupId>org.apache.camel</groupId>
  <artifactId>camel-base64</artifactId>
  <version>x.x.x</version>  <!-- use the same version as your Camel core version -->
</dependency>