Class Jackson2JsonRedisSerializer<T>
- All Implemented Interfaces:
RedisSerializer<T>
RedisSerializer that can read and write JSON using
Jackson's and
Jackson Databind ObjectMapper.
This converter can be used to bind to typed beans, or untyped HashMap instances.
Note:Null objects are serialized as empty arrays and vice versa.
- Since:
- 1.2
- Author:
- Thomas Darimont
-
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescriptionJackson2JsonRedisSerializer(com.fasterxml.jackson.databind.JavaType javaType) Creates a newJackson2JsonRedisSerializerfor the given targetJavaType.Jackson2JsonRedisSerializer(Class<T> type) Creates a newJackson2JsonRedisSerializerfor the given targetClass. -
Method Summary
Modifier and TypeMethodDescriptiondeserialize(byte[] bytes) Deserialize an object from the given binary data.protected com.fasterxml.jackson.databind.JavaTypegetJavaType(Class<?> clazz) Returns the JacksonJavaTypefor the specific class.byte[]Serialize the given object to binary data.voidsetObjectMapper(com.fasterxml.jackson.databind.ObjectMapper objectMapper) Sets theObjectMapperfor this view.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.data.redis.serializer.RedisSerializer
canSerialize, getTargetType
-
Field Details
-
DEFAULT_CHARSET
-
-
Constructor Details
-
Jackson2JsonRedisSerializer
Creates a newJackson2JsonRedisSerializerfor the given targetClass.- Parameters:
type-
-
Jackson2JsonRedisSerializer
public Jackson2JsonRedisSerializer(com.fasterxml.jackson.databind.JavaType javaType) Creates a newJackson2JsonRedisSerializerfor the given targetJavaType.- Parameters:
javaType-
-
-
Method Details
-
deserialize
Description copied from interface:RedisSerializerDeserialize an object from the given binary data.- Specified by:
deserializein interfaceRedisSerializer<T>- Parameters:
bytes- object binary representation. Can be null.- Returns:
- the equivalent object instance. Can be null.
- Throws:
SerializationException
-
serialize
Description copied from interface:RedisSerializerSerialize the given object to binary data.- Specified by:
serializein interfaceRedisSerializer<T>- Parameters:
t- object to serialize. Can be null.- Returns:
- the equivalent binary data. Can be null.
- Throws:
SerializationException
-
setObjectMapper
public void setObjectMapper(com.fasterxml.jackson.databind.ObjectMapper objectMapper) Sets theObjectMapperfor this view. If not set, a defaultObjectMapperis used.Setting a custom-configured
ObjectMapperis one way to take further control of the JSON serialization process. For example, an extendedSerializerFactorycan be configured that provides custom serializers for specific types. The other option for refining the serialization process is to use Jackson's provided annotations on the types to be serialized, in which case a custom-configured ObjectMapper is unnecessary. -
getJavaType
Returns the JacksonJavaTypefor the specific class.Default implementation returns
TypeFactory.constructType(java.lang.reflect.Type), but this can be overridden in subclasses, to allow for custom generic collection handling. For instance:protected JavaType getJavaType(Class<?> clazz) { if (List.class.isAssignableFrom(clazz)) { return TypeFactory.defaultInstance().constructCollectionType(ArrayList.class, MyBean.class); } else { return super.getJavaType(clazz); } }- Parameters:
clazz- the class to return the java type for- Returns:
- the java type
-