com.fasterxml.jackson.databind.ser.std

Class StdSerializer<T>

    • Field Detail

      • _handledType

        protected final Class<T> _handledType
        Nominal type supported, usually declared type of property for which serializer is used.
    • Constructor Detail

      • StdSerializer

        protected StdSerializer(Class<T> t)
      • StdSerializer

        protected StdSerializer(JavaType type)
      • StdSerializer

        protected StdSerializer(Class<?> t,
                     boolean dummy)
        Alternate constructor that is (alas!) needed to work around kinks of generic type handling
      • StdSerializer

        protected StdSerializer(StdSerializer<?> src)
        Since:
        2.6
    • Method Detail

      • handledType

        public Class<T> handledType()
        Description copied from class: JsonSerializer
        Method for accessing type of Objects this serializer can handle. Note that this information is not guaranteed to be exact -- it may be a more generic (super-type) -- but it should not be incorrect (return a non-related type).

        Default implementation will return null, which essentially means same as returning Object.class would; that is, that nothing is known about handled type.

        Overrides:
        handledType in class JsonSerializer<T>
      • serialize

        public abstract void serialize(T value,
                     JsonGenerator gen,
                     SerializerProvider provider)
                                throws IOException
        Description copied from class: JsonSerializer
        Method that can be called to ask implementation to serialize values of type this serializer handles.
        Specified by:
        serialize in class JsonSerializer<T>
        Parameters:
        value - Value to serialize; can not be null.
        gen - Generator used to output resulting Json content
        provider - Provider that can be used to get serializers for serializing Objects value contains, if any.
        Throws:
        IOException
      • createObjectNode

        protected ObjectNode createObjectNode()
      • createSchemaNode

        protected ObjectNode createSchemaNode(String type,
                                  boolean isOptional)
      • wrapAndThrow

        public void wrapAndThrow(SerializerProvider provider,
                        Throwable t,
                        Object bean,
                        String fieldName)
                          throws IOException
        Method that will modify caught exception (passed in as argument) as necessary to include reference information, and to ensure it is a subtype of IOException, or an unchecked exception.

        Rules for wrapping and unwrapping are bit complicated; essentially:

        • Errors are to be passed as is (if uncovered via unwrapping)
        • "Plain" IOExceptions (ones that are not of type JsonMappingException are to be passed as is

        Throws:
        IOException
      • isDefaultSerializer

        protected boolean isDefaultSerializer(JsonSerializer<?> serializer)
        Method that can be called to determine if given serializer is the default serializer Jackson uses; as opposed to a custom serializer installed by a module or calling application. Determination is done using JacksonStdImpl annotation on serializer class.
      • findConvertingContentSerializer

        protected JsonSerializer<?> findConvertingContentSerializer(SerializerProvider provider,
                                                        BeanProperty prop,
                                                        JsonSerializer<?> existingSerializer)
                                                             throws JsonMappingException
        Helper method that can be used to see if specified property has annotation indicating that a converter is to be used for contained values (contents of structured types; array/List/Map values)
        Parameters:
        existingSerializer - (optional) configured content serializer if one already exists.
        Throws:
        JsonMappingException
        Since:
        2.2

Copyright © 2008–2018 FasterXML. All rights reserved.