|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object com.fasterxml.jackson.databind.JsonDeserializer<T> com.fasterxml.jackson.databind.deser.std.StdDeserializer<T> com.fasterxml.jackson.databind.deser.std.ContainerDeserializerBase<Map<Object,Object>> com.fasterxml.jackson.databind.deser.std.MapDeserializer
public class MapDeserializer
Basic serializer that can take Json "Object" structure and
construct a Map
instance, with typed contents.
Note: for untyped content (one indicated by passing Object.class
as the type), UntypedObjectDeserializer
is used instead.
It can also construct Map
s, but not with specific
POJO types, only other containers and primitives/wrappers.
Nested Class Summary |
---|
Nested classes/interfaces inherited from class com.fasterxml.jackson.databind.JsonDeserializer |
---|
JsonDeserializer.None |
Field Summary | |
---|---|
protected JsonDeserializer<Object> |
_delegateDeserializer
Deserializer that is used iff delegate-based creator is to be used for deserializing from JSON Object. |
protected boolean |
_hasDefaultCreator
|
protected HashSet<String> |
_ignorableProperties
|
protected KeyDeserializer |
_keyDeserializer
Key deserializer to use; either passed via constructor (when indicated by annotations), or resolved when resolve(com.fasterxml.jackson.databind.DeserializationContext) is called; |
protected JavaType |
_mapType
|
protected PropertyBasedCreator |
_propertyBasedCreator
If the Map is to be instantiated using non-default constructor or factory method that takes one or more named properties as argument(s), this creator is used for instantiation. |
protected boolean |
_standardStringKey
Flag set to indicate that the key type is String (or Object , for
which String is acceptable), and that the
default Jackson key deserializer would be used. |
protected JsonDeserializer<Object> |
_valueDeserializer
Value deserializer. |
protected ValueInstantiator |
_valueInstantiator
|
protected TypeDeserializer |
_valueTypeDeserializer
If value instances have polymorphic type information, this is the type deserializer that can handle it |
Fields inherited from class com.fasterxml.jackson.databind.deser.std.StdDeserializer |
---|
_valueClass |
Constructor Summary | |
---|---|
|
MapDeserializer(JavaType mapType,
ValueInstantiator valueInstantiator,
KeyDeserializer keyDeser,
JsonDeserializer<Object> valueDeser,
TypeDeserializer valueTypeDeser)
|
protected |
MapDeserializer(MapDeserializer src)
Copy-constructor that can be used by sub-classes to allow copy-on-write styling copying of settings of an existing instance. |
protected |
MapDeserializer(MapDeserializer src,
KeyDeserializer keyDeser,
JsonDeserializer<Object> valueDeser,
TypeDeserializer valueTypeDeser,
HashSet<String> ignorable)
|
Method Summary | |
---|---|
Map<Object,Object> |
_deserializeUsingCreator(com.fasterxml.jackson.core.JsonParser jp,
DeserializationContext ctxt)
|
protected boolean |
_isStdKeyDeser(JavaType mapType,
KeyDeserializer keyDeser)
Helper method used to check whether we can just use the default key deserialization, where JSON String becomes Java String. |
protected void |
_readAndBind(com.fasterxml.jackson.core.JsonParser jp,
DeserializationContext ctxt,
Map<Object,Object> result)
|
protected void |
_readAndBindStringMap(com.fasterxml.jackson.core.JsonParser jp,
DeserializationContext ctxt,
Map<Object,Object> result)
Optimized method used when keys can be deserialized as plain old String s, and there is no custom deserialized
specified. |
JsonDeserializer<?> |
createContextual(DeserializationContext ctxt,
BeanProperty property)
Method called to finalize setup of this deserializer, when it is known for which property deserializer is needed for. |
Map<Object,Object> |
deserialize(com.fasterxml.jackson.core.JsonParser jp,
DeserializationContext ctxt)
Method that can be called to ask implementation to deserialize JSON content into the value type this serializer handles. |
Map<Object,Object> |
deserialize(com.fasterxml.jackson.core.JsonParser jp,
DeserializationContext ctxt,
Map<Object,Object> result)
Alternate deserialization method (compared to the most commonly used, JsonDeserializer.deserialize(JsonParser, DeserializationContext) ),
which takes in initialized value instance, to be
configured and/or populated by deserializer. |
Object |
deserializeWithType(com.fasterxml.jackson.core.JsonParser jp,
DeserializationContext ctxt,
TypeDeserializer typeDeserializer)
Base implementation that does not assume specific type inclusion mechanism. |
JsonDeserializer<Object> |
getContentDeserializer()
Accesor for deserializer use for deserializing content values. |
JavaType |
getContentType()
Accessor for declared type of contained value elements; either exact type, or one of its supertypes. |
Class<?> |
getMapClass()
|
JavaType |
getValueType()
Exact structured type deserializer handles, if known. |
void |
resolve(DeserializationContext ctxt)
Method called after deserializer instance has been constructed (and registered as necessary by provider objects), but before it has returned it to the caller. |
void |
setIgnorableProperties(String[] ignorable)
|
protected MapDeserializer |
withResolved(KeyDeserializer keyDeser,
TypeDeserializer valueTypeDeser,
JsonDeserializer<?> valueDeser,
HashSet<String> ignorable)
Fluent factory method used to create a copy with slightly different settings. |
protected void |
wrapAndThrow(Throwable t,
Object ref)
|
Methods inherited from class com.fasterxml.jackson.databind.deser.std.StdDeserializer |
---|
_parseBoolean, _parseBooleanFromNumber, _parseBooleanPrimitive, _parseByte, _parseDate, _parseDouble, _parseDoublePrimitive, _parseFloat, _parseFloatPrimitive, _parseInteger, _parseIntPrimitive, _parseLong, _parseLongPrimitive, _parseShort, _parseShortPrimitive, findDeserializer, getValueClass, handleUnknownProperty, isDefaultDeserializer, isDefaultKeyDeserializer, parseDouble |
Methods inherited from class com.fasterxml.jackson.databind.JsonDeserializer |
---|
getEmptyValue, getKnownPropertyNames, getNullValue, getObjectIdReader, isCachable, unwrappingDeserializer |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected final JavaType _mapType
protected final KeyDeserializer _keyDeserializer
resolve(com.fasterxml.jackson.databind.DeserializationContext)
is called;
protected boolean _standardStringKey
String
(or Object
, for
which String is acceptable), and that the
default Jackson key deserializer would be used.
If both are true, can optimize handling.
protected final JsonDeserializer<Object> _valueDeserializer
protected final TypeDeserializer _valueTypeDeserializer
protected final ValueInstantiator _valueInstantiator
protected final boolean _hasDefaultCreator
protected JsonDeserializer<Object> _delegateDeserializer
protected PropertyBasedCreator _propertyBasedCreator
protected HashSet<String> _ignorableProperties
Constructor Detail |
---|
public MapDeserializer(JavaType mapType, ValueInstantiator valueInstantiator, KeyDeserializer keyDeser, JsonDeserializer<Object> valueDeser, TypeDeserializer valueTypeDeser)
protected MapDeserializer(MapDeserializer src)
protected MapDeserializer(MapDeserializer src, KeyDeserializer keyDeser, JsonDeserializer<Object> valueDeser, TypeDeserializer valueTypeDeser, HashSet<String> ignorable)
Method Detail |
---|
protected MapDeserializer withResolved(KeyDeserializer keyDeser, TypeDeserializer valueTypeDeser, JsonDeserializer<?> valueDeser, HashSet<String> ignorable)
protected final boolean _isStdKeyDeser(JavaType mapType, KeyDeserializer keyDeser)
public void setIgnorableProperties(String[] ignorable)
public void resolve(DeserializationContext ctxt) throws JsonMappingException
ResolvableDeserializer
resolve
in interface ResolvableDeserializer
ctxt
- Context to use for accessing configuration, resolving
secondary deserializers
JsonMappingException
public JsonDeserializer<?> createContextual(DeserializationContext ctxt, BeanProperty property) throws JsonMappingException
createContextual
in interface ContextualDeserializer
ctxt
- Deserialization context to access configuration, additional
deserializers that may be needed by this deserializerproperty
- Method, field or constructor parameter that represents the property
(and is used to assign deserialized value).
Should be available; but there may be cases where caller can not provide it and
null is passed instead (in which case impls usually pass 'this' deserializer as is)
JsonMappingException
public JavaType getContentType()
ContainerDeserializerBase
getContentType
in class ContainerDeserializerBase<Map<Object,Object>>
public JsonDeserializer<Object> getContentDeserializer()
ContainerDeserializerBase
getContentDeserializer
in class ContainerDeserializerBase<Map<Object,Object>>
public Map<Object,Object> deserialize(com.fasterxml.jackson.core.JsonParser jp, DeserializationContext ctxt) throws IOException, com.fasterxml.jackson.core.JsonProcessingException
JsonDeserializer
Pre-condition for this method is that the parser points to the first event that is part of value to deserializer (and which is never JSON 'null' literal, more on this below): for simple types it may be the only value; and for structured types the Object start marker. Post-condition is that the parser will point to the last event that is part of deserialized value (or in case deserialization fails, event that was not recognized or usable, which may be the same event as the one it pointed to upon call).
Note that this method is never called for JSON null literal, and thus deserializers need (and should) not check for it.
deserialize
in class JsonDeserializer<Map<Object,Object>>
jp
- Parsed used for reading JSON contentctxt
- Context that can be used to access information about
this deserialization activity.
IOException
com.fasterxml.jackson.core.JsonProcessingException
public Map<Object,Object> deserialize(com.fasterxml.jackson.core.JsonParser jp, DeserializationContext ctxt, Map<Object,Object> result) throws IOException, com.fasterxml.jackson.core.JsonProcessingException
JsonDeserializer
JsonDeserializer.deserialize(JsonParser, DeserializationContext)
),
which takes in initialized value instance, to be
configured and/or populated by deserializer.
Method is not necessarily used for all supported types; most commonly
it is used
for Collections and Maps.
Default implementation just throws
UnsupportedOperationException
, to indicate that types
that do not explicitly add support do not necessarily support
update-existing-value operation (esp. immutable types)
deserialize
in class JsonDeserializer<Map<Object,Object>>
IOException
com.fasterxml.jackson.core.JsonProcessingException
public Object deserializeWithType(com.fasterxml.jackson.core.JsonParser jp, DeserializationContext ctxt, TypeDeserializer typeDeserializer) throws IOException, com.fasterxml.jackson.core.JsonProcessingException
StdDeserializer
deserializeWithType
in class StdDeserializer<Map<Object,Object>>
typeDeserializer
- Deserializer to use for handling type information
IOException
com.fasterxml.jackson.core.JsonProcessingException
public final Class<?> getMapClass()
public JavaType getValueType()
StdDeserializer
Default implementation just returns null.
getValueType
in class StdDeserializer<Map<Object,Object>>
protected final void _readAndBind(com.fasterxml.jackson.core.JsonParser jp, DeserializationContext ctxt, Map<Object,Object> result) throws IOException, com.fasterxml.jackson.core.JsonProcessingException
IOException
com.fasterxml.jackson.core.JsonProcessingException
protected final void _readAndBindStringMap(com.fasterxml.jackson.core.JsonParser jp, DeserializationContext ctxt, Map<Object,Object> result) throws IOException, com.fasterxml.jackson.core.JsonProcessingException
String
s, and there is no custom deserialized
specified.
IOException
com.fasterxml.jackson.core.JsonProcessingException
public Map<Object,Object> _deserializeUsingCreator(com.fasterxml.jackson.core.JsonParser jp, DeserializationContext ctxt) throws IOException, com.fasterxml.jackson.core.JsonProcessingException
IOException
com.fasterxml.jackson.core.JsonProcessingException
protected void wrapAndThrow(Throwable t, Object ref) throws IOException
IOException
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |