Project to build Jackson module to support JSON serialization and deserialization of Hibernate (https://hibernate.org) specific data types and properties; and features like lazy-loading.
Module is usable and supported for Jackson 2.x. and used by non-trivial number of developers and projects.
Currently (October 2025) module is NOT supported for Jackson 3.x due to lack of active maintainer. It is considered Deprecated as part of JSTEP-9.
Note: Hibernate 4.x, 5.x, 6.x and 7.x are supported (5.x starting with Jackson 2.6; 6.x with Jackson 2.15 and 7.x with Jackson 2.20) but they require different jars, and Maven artifact names (and jar names differ).
This document refers to "Hibernate 5" version, but changes with 4.x/6.x/7.x should require little more than replacing "5" in names with "4", "6" or "7".
Hibernate 3.x was supported up to Jackson 2.12 but is no longer supported at and after 2.13
Jackson 2.13 adds Support for "Hibernate 5 Jakarta" variant (for Hibernate 5.5 and beyond); see below for more information.
Jackson 2.15 adds Support for Hibernate 6.x; see below for more information.
Jackson 2.20 adds Support for Hibernate 7.x; see below for more information.
Before Jackson 2.15, baseline JDK needed for building for JDK 8 and all module variants worked on Java 8.
With Jackson 2.15, JDK 11 will be required to build: all modules run on Java 8 except for Hibernate 6.x module which requires Java 11 like Hibernate 6.x itself.
With Jackson 2.20, JDK 17 will be required to build: 4.x and 5.x modules run on Java 8, 6.x on 11 and Hibernate 7.x module requires Java 17 like Hibernate 7.x itself.
Due to changes related to Java EE to Jakarta EE transition (also known as "JAXB to Jakarta" etc etc), there are 2 variants of Hibernate 5 module:
- One that works with "old" JAXB/JavaEE APIs: jackson-datatype-hibernate5
- One that works with "new" Jakarta APIs: jackson-datatype-hibernate5-jakarta
Note that for Hibernate 4.x only old APIs matter; and for 6.x and later only new (Jakarta) APIs are used -- so there are no separate modules.
To use module on Maven-based projects, use following dependency (with whatever is the latest version available):
<dependency>
  <groupId>com.fasterxml.jackson.datatype</groupId>
  <artifactId>jackson-datatype-hibernate5</artifactId>
  <version>2.20.0</version>
</dependency>or whatever version is most up-to-date at the moment;
Note that you need to use "jackson-datatype-hibernate4" for Hibernate 4.x.
<dependency>
  <groupId>com.fasterxml.jackson.datatype</groupId>
  <artifactId>jackson-datatype-hibernate4</artifactId>
  <version>2.20.0</version>
</dependency>if you plan to use Hibernate 5.5 with the Jakarta Persistence API 3.0; you will need the jakarta suffixed dependency for Hibernate 5.5:
<dependency>
  <groupId>com.fasterxml.jackson.datatype</groupId>
  <artifactId>jackson-datatype-hibernate5-jakarta</artifactId>
  <version>2.20.0</version>
</dependency>but you will need to use "jackson-datatype-hibernate6" for Hibernate 6.x: (for which only "jakarta" version exists).
<dependency>
  <groupId>com.fasterxml.jackson.datatype</groupId>
  <artifactId>jackson-datatype-hibernate6</artifactId>
  <version>2.20.0</version>
</dependency>and finally, for Hibernate 7.x
<dependency>
    <groupId>com.fasterxml.jackson.datatype</groupId>
    <artifactId>jackson-datatype-hibernate7</artifactId>
    <!-- added in Jackson 2.20.0: -->
    <version>2.20.0</version>
</dependency>Like all standard Jackson modules (libraries that implement Module interface), registration is done as follows:
ObjectMapper mapper = new ObjectMapper();
// for Hibernate 4.x:
mapper.registerModule(new Hibernate4Module());
// OR newer style
ObjectMapper mapper = JsonMapper.builder()
    .addModule(new Hibernate4Module()));
    .build();
// or, for Hibernate 5.x
ObjectMapper mapper = JsonMapper.builder()
    .addModule(new Hibernate5Module()));
    .build();
// or, for Hibernate 5.5+ with Jakarta
ObjectMapper mapper = JsonMapper.builder()
    .addModule(new Hibernate5JakartaModule()));
    .build();
// or, for Hibernate 6.x
ObjectMapper mapper = JsonMapper.builder()
    .addModule(new Hibernate6Module()));
    .build();
// or, for Hibernate 7.x
ObjectMapper mapper = JsonMapper.builder()
    .addModule(new Hibernate7Module()));
    .build();after which functionality is available for all normal Jackson operations.
Although more common way would be to register the module explicitly, it is alternatively possible to just sub-class ObjectMapper and register the module in constructor.
public class HibernateAwareObjectMapper extends ObjectMapper {
    public HibernateAwareObjectMapper() {
        // This for Hibernate 5; change 5 to 4 if you need to support
        // Hibernate 4 instead
        registerModule(new Hibernate5Module());
    }
}Then add it as the objectmapper to be used
    <mvc:annotation-driven>
        <mvc:message-converters>
            <!-- Use the HibernateAware mapper instead of the default -->
            <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
                <property name="objectMapper">
                    <bean class="path.to.your.HibernateAwareObjectMapper" />
                </property>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>If mvc:annotation-driven is not being used, it can be added as a jsonconverter to the messageconverters of RequestMappingHandlerAdapter.
Project Wiki contains links to Javadocs and downloadable jars (from Central Maven repository).