Package org.codehaus.jackson.map.ser.std
Class MapSerializer
- java.lang.Object
-
- org.codehaus.jackson.map.JsonSerializer<T>
-
- org.codehaus.jackson.map.ser.std.SerializerBase<T>
-
- org.codehaus.jackson.map.ser.std.ContainerSerializerBase<java.util.Map<?,?>>
-
- org.codehaus.jackson.map.ser.std.MapSerializer
-
- All Implemented Interfaces:
ResolvableSerializer,SchemaAware
- Direct Known Subclasses:
MapSerializer
public class MapSerializer extends ContainerSerializerBase<java.util.Map<?,?>> implements ResolvableSerializer
Standard serializer implementation for serializing {link java.util.Map} types.Note: about the only configurable setting currently is ability to filter out entries with specified names.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.codehaus.jackson.map.JsonSerializer
JsonSerializer.None
-
-
Field Summary
Fields Modifier and Type Field Description protected PropertySerializerMap_dynamicValueSerializersIf value type can not be statically determined, mapping from runtime value types to serializers are stored in this object.protected java.util.HashSet<java.lang.String>_ignoredEntriesSet of entries to omit during serialization, if anyprotected JsonSerializer<java.lang.Object>_keySerializerKey serializer to use, if it can be statically determinedprotected JavaType_keyTypeDeclared type of keysprotected BeanProperty_propertyMap-valued property being serialized with this instanceprotected JsonSerializer<java.lang.Object>_valueSerializerValue serializer to use, if it can be statically determinedprotected JavaType_valueTypeDeclared type of contained valuesprotected boolean_valueTypeIsStaticWhether static types should be used for serialization of values or not (if not, dynamic runtime type is used)protected TypeSerializer_valueTypeSerializerType identifier serializer used for values, if any.protected static JavaTypeUNSPECIFIED_TYPE-
Fields inherited from class org.codehaus.jackson.map.ser.std.SerializerBase
_handledType
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedMapSerializer()protectedMapSerializer(java.util.HashSet<java.lang.String> ignoredEntries, JavaType keyType, JavaType valueType, boolean valueTypeIsStatic, TypeSerializer vts, JsonSerializer<java.lang.Object> keySerializer, JsonSerializer<java.lang.Object> valueSerializer, BeanProperty property)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected JsonSerializer<java.lang.Object>_findAndAddDynamic(PropertySerializerMap map, java.lang.Class<?> type, SerializerProvider provider)protected JsonSerializer<java.lang.Object>_findAndAddDynamic(PropertySerializerMap map, JavaType type, SerializerProvider provider)ContainerSerializerBase<?>_withValueTypeSerializer(TypeSerializer vts)static MapSerializerconstruct(java.lang.String[] ignoredList, JavaType mapType, boolean staticValueType, TypeSerializer vts, BeanProperty property)Deprecated.As of 1.8; use the variant with more argumentsstatic MapSerializerconstruct(java.lang.String[] ignoredList, JavaType mapType, boolean staticValueType, TypeSerializer vts, BeanProperty property, JsonSerializer<java.lang.Object> keySerializer, JsonSerializer<java.lang.Object> valueSerializer)JsonNodegetSchema(SerializerProvider provider, java.lang.reflect.Type typeHint)Note: since Jackson 1.9, default implementation claims type is "string"voidresolve(SerializerProvider provider)Need to get callback to resolve value serializer, if static typing is used (either being forced, or because value type is final)voidserialize(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider)Method that can be called to ask implementation to serialize values of type this serializer handles.voidserializeFields(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider)Method called to serialize fields, when the value type is not statically known.protected voidserializeFieldsUsing(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider, JsonSerializer<java.lang.Object> ser)Method called to serialize fields, when the value type is statically known, so that value serializer is passed and does not need to be fetched from provider.protected voidserializeTypedFields(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider)voidserializeWithType(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider, TypeSerializer typeSer)Method that can be called to ask implementation to serialize values of type this serializer handles, using specified type serializer for embedding necessary type information.-
Methods inherited from class org.codehaus.jackson.map.ser.std.ContainerSerializerBase
withValueTypeSerializer
-
Methods inherited from class org.codehaus.jackson.map.ser.std.SerializerBase
createObjectNode, createSchemaNode, createSchemaNode, handledType, isDefaultSerializer, wrapAndThrow, wrapAndThrow, wrapAndThrow, wrapAndThrow
-
Methods inherited from class org.codehaus.jackson.map.JsonSerializer
isUnwrappingSerializer, unwrappingSerializer
-
-
-
-
Field Detail
-
UNSPECIFIED_TYPE
protected static final JavaType UNSPECIFIED_TYPE
-
_property
protected final BeanProperty _property
Map-valued property being serialized with this instance- Since:
- 1.7
-
_ignoredEntries
protected final java.util.HashSet<java.lang.String> _ignoredEntries
Set of entries to omit during serialization, if any
-
_valueTypeIsStatic
protected final boolean _valueTypeIsStatic
Whether static types should be used for serialization of values or not (if not, dynamic runtime type is used)
-
_keyType
protected final JavaType _keyType
Declared type of keys- Since:
- 1.7
-
_valueType
protected final JavaType _valueType
Declared type of contained values
-
_keySerializer
protected JsonSerializer<java.lang.Object> _keySerializer
Key serializer to use, if it can be statically determined- Since:
- 1.7
-
_valueSerializer
protected JsonSerializer<java.lang.Object> _valueSerializer
Value serializer to use, if it can be statically determined- Since:
- 1.5
-
_valueTypeSerializer
protected final TypeSerializer _valueTypeSerializer
Type identifier serializer used for values, if any.
-
_dynamicValueSerializers
protected PropertySerializerMap _dynamicValueSerializers
If value type can not be statically determined, mapping from runtime value types to serializers are stored in this object.- Since:
- 1.8
-
-
Constructor Detail
-
MapSerializer
protected MapSerializer()
-
MapSerializer
protected MapSerializer(java.util.HashSet<java.lang.String> ignoredEntries, JavaType keyType, JavaType valueType, boolean valueTypeIsStatic, TypeSerializer vts, JsonSerializer<java.lang.Object> keySerializer, JsonSerializer<java.lang.Object> valueSerializer, BeanProperty property)
-
-
Method Detail
-
_withValueTypeSerializer
public ContainerSerializerBase<?> _withValueTypeSerializer(TypeSerializer vts)
- Specified by:
_withValueTypeSerializerin classContainerSerializerBase<java.util.Map<?,?>>
-
construct
@Deprecated public static MapSerializer construct(java.lang.String[] ignoredList, JavaType mapType, boolean staticValueType, TypeSerializer vts, BeanProperty property)
Deprecated.As of 1.8; use the variant with more argumentsFactory method used to construct Map serializers.- Parameters:
ignoredList- Array of entry names that are to be filtered on serialization; null if nonemapType- Declared type information (needed for static typing)staticValueType- Whether static typing should be used for the Map (which includes its contents)vts- Type serializer to use for map entry values, if any
-
construct
public static MapSerializer construct(java.lang.String[] ignoredList, JavaType mapType, boolean staticValueType, TypeSerializer vts, BeanProperty property, JsonSerializer<java.lang.Object> keySerializer, JsonSerializer<java.lang.Object> valueSerializer)
-
serialize
public void serialize(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider) throws java.io.IOException, JsonGenerationExceptionDescription copied from class:JsonSerializerMethod that can be called to ask implementation to serialize values of type this serializer handles.- Specified by:
serializein classSerializerBase<java.util.Map<?,?>>- Parameters:
value- Value to serialize; can not be null.jgen- Generator used to output resulting Json contentprovider- Provider that can be used to get serializers for serializing Objects value contains, if any.- Throws:
java.io.IOExceptionJsonGenerationException
-
serializeWithType
public void serializeWithType(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider, TypeSerializer typeSer) throws java.io.IOException, JsonGenerationExceptionDescription copied from class:JsonSerializerMethod that can be called to ask implementation to serialize values of type this serializer handles, using specified type serializer for embedding necessary type information.Default implementation will ignore serialization of type information, and just calls
JsonSerializer.serialize(T, org.codehaus.jackson.JsonGenerator, org.codehaus.jackson.map.SerializerProvider): serializers that can embed type information should override this to implement actual handling. Most common such handling is done by something like:// note: method to call depends on whether this type is serialized as JSON scalar, object or Array! typeSer.writeTypePrefixForScalar(value, jgen); serialize(value, jgen, provider); typeSer.writeTypeSuffixForScalar(value, jgen);
- Overrides:
serializeWithTypein classJsonSerializer<java.util.Map<?,?>>- Parameters:
value- Value to serialize; can not be null.jgen- Generator used to output resulting Json contentprovider- Provider that can be used to get serializers for serializing Objects value contains, if any.typeSer- Type serializer to use for including type information- Throws:
java.io.IOExceptionJsonGenerationException
-
serializeFields
public void serializeFields(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider) throws java.io.IOException, JsonGenerationExceptionMethod called to serialize fields, when the value type is not statically known.- Throws:
java.io.IOExceptionJsonGenerationException
-
serializeFieldsUsing
protected void serializeFieldsUsing(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider, JsonSerializer<java.lang.Object> ser) throws java.io.IOException, JsonGenerationExceptionMethod called to serialize fields, when the value type is statically known, so that value serializer is passed and does not need to be fetched from provider.- Throws:
java.io.IOExceptionJsonGenerationException
-
serializeTypedFields
protected void serializeTypedFields(java.util.Map<?,?> value, JsonGenerator jgen, SerializerProvider provider) throws java.io.IOException, JsonGenerationException- Throws:
java.io.IOExceptionJsonGenerationException
-
getSchema
public JsonNode getSchema(SerializerProvider provider, java.lang.reflect.Type typeHint)
Description copied from class:SerializerBaseNote: since Jackson 1.9, default implementation claims type is "string"- Specified by:
getSchemain interfaceSchemaAware- Overrides:
getSchemain classSerializerBase<java.util.Map<?,?>>- Parameters:
provider- The serializer provider.typeHint- A hint about the type.- Returns:
- Json-schema for this serializer.
-
resolve
public void resolve(SerializerProvider provider) throws JsonMappingException
Need to get callback to resolve value serializer, if static typing is used (either being forced, or because value type is final)- Specified by:
resolvein interfaceResolvableSerializer- Parameters:
provider- Provider that has constructed serializer this method is called on.- Throws:
JsonMappingException
-
_findAndAddDynamic
protected final JsonSerializer<java.lang.Object> _findAndAddDynamic(PropertySerializerMap map, java.lang.Class<?> type, SerializerProvider provider) throws JsonMappingException
- Throws:
JsonMappingException
-
_findAndAddDynamic
protected final JsonSerializer<java.lang.Object> _findAndAddDynamic(PropertySerializerMap map, JavaType type, SerializerProvider provider) throws JsonMappingException
- Throws:
JsonMappingException
-
-