Jackson Full Data Binding: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
Line 63: Line 63:
=Annotations=
=Annotations=


{{Internal|Jackson Annotations}}
{{Internal|Jackson Annotations|Jackson Annotations}}


=Abstract Class Handling=
=Abstract Class Handling=

Revision as of 22:25, 26 February 2017

Internal

Overview

JSON to Java

import com.fasterxml.jackson.databind.ObjectMapper;

InputStream is = ...;

ObjectMapper mapper = new ObjectMapper();

Root root = mapper.readValue(is, Root.class);

This is a generic conversion method, assuming that the JSON content matches the internal structure of the type <T>:

public static <T> T fromJson(String json, Class<? extends T> c) throws JsonConversionException {

    try {
        ObjectMapper objectMapper = new ObjectMapper();
        return objectMapper.readValue(new ByteArrayInputStream(json.getBytes()), c);
    }
    catch (Exception e) {
       throw new JsonConversionException(e);
    }
}

Java to JSON

ObjectMapper will introspect a Java object coded according to the Java Beans conventions and output it as JSON content.

The method names (without the "get") will be used as field names.

Example:

import com.fasterxml.jackson.databind.ObjectMapper;

ByteArrayOutputStream baos = new ByteArrayOutputStream();

ObjectMapper mapper = new ObjectMapper();
Root root = ... // some hierarchical object
mapper.writeValue(baos, root);
System.out.println(new String(baos.toByteArray()));

Code Example

Full Data Binding Example

Generics Handling

To enable generic type information (like "Map<String,Object>"), you have to use TypeReference container. See http://wiki.fasterxml.com/JacksonDataBinding.

Full Data Binding and Generics Example

Annotations

Jackson Annotations

Abstract Class Handling

{{{2}}}

Custom Deserializers

{{{2}}}