Skip to content
Snippets Groups Projects
Select Git revision
  • master
  • pristine-tar
  • upstream
  • debian/2.7.8-5
  • debian/2.7.8-4
  • debian/2.7.8-3
  • debian/2.7.8-2
  • debian/2.7.8-1
  • upstream/2.7.8
  • debian/2.7.3-1
  • upstream/2.7.3
  • debian/2.4.3-1
  • upstream/2.4.3
13 results

jackson-dataformat-cbor

  • Clone with SSH
  • Clone with HTTPS
  • Overview

    Jackson (Java) data format module that supports reading and writing CBOR ("Concise Binary Object Representation") encoded data. Module extends standard Jackson streaming API (JsonFactory, JsonParser, JsonGenerator), and as such works seamlessly with all the higher level data abstractions (data binding, tree model, and pluggable extensions).

    Status

    As of version 2.4.0, this module is considered stable and production quality. Similar to JSON- and other JSON-like backends, it implementsfull support for all levels (streaming, data-binding, tree model).

    Build Status Maven Central Javadoc

    Limitations

    Minor limitations exist with respect to advanced type-handling of CBOR format:

    • While tags are written for some types (BigDecimal, BigInteger), they are not handling on parsing

    Maven dependency

    To use this extension on Maven-based projects, use following dependency:

    <dependency>
      <groupId>com.fasterxml.jackson.dataformat</groupId>
      <artifactId>jackson-dataformat-cbor</artifactId>
      <version>2.4.0</version>
    </dependency>

    (or whatever version is most up-to-date at the moment)

    Usage

    Basic usage is by using CborFactory in places where you would usually use JsonFactory:

    CBORFactory f = new CBORFactory();
    ObjectMapper mapper = new ObjectMapper(f);
    // and then read/write data as usual
    SomeType value = ...;
    byte[] cborData = mapper.writeValueAsBytes(value);
    SomeType otherValue = mapper.readValue(cborData, SomeType.class);

    Implementation allows use of any of 3 main operating modes:

    • Streaming API (CBORParser and CBORGenerator)
    • Databinding (via ObjectMapper / ObjectReader / ObjectWriter)
    • Tree Model (using TreeNode, or its concrete subtype, JsonNode -- not JSON-specific despite the name)

    and all the usual data-binding use cases exactly like when using JSON or Smile (2 canonical 100% supported Jackson data formats).

    Documentation

    • Wiki (includes Javadocs)