Class AbstractHttpMessageConverter<T>
java.lang.Object
org.springframework.http.converter.AbstractHttpMessageConverter<T>
- Type Parameters:
T
- the converted object type
- All Implemented Interfaces:
HttpMessageConverter<T>
- Direct Known Subclasses:
AbstractGenericHttpMessageConverter
,AbstractSmartHttpMessageConverter
,AbstractWireFeedHttpMessageConverter
,AbstractXmlHttpMessageConverter
,ByteArrayHttpMessageConverter
,ObjectToStringHttpMessageConverter
,ProtobufHttpMessageConverter
,ResourceHttpMessageConverter
,SourceHttpMessageConverter
,StringHttpMessageConverter
public abstract class AbstractHttpMessageConverter<T>
extends Object
implements HttpMessageConverter<T>
Abstract base class for most
HttpMessageConverter
implementations.
This base class adds support for setting supported MediaTypes
, through the
supportedMediaTypes
bean property. It also adds
support for Content-Type
and Content-Length
when writing to output messages.
- Since:
- 3.0
- Author:
- Arjen Poutsma, Juergen Hoeller, Sebastien Deleuze
-
Field Summary
Modifier and TypeFieldDescriptionprotected final org.apache.commons.logging.Log
Logger available to subclasses. -
Constructor Summary
ModifierConstructorDescriptionprotected
Construct anAbstractHttpMessageConverter
with no supported media types.protected
AbstractHttpMessageConverter
(Charset defaultCharset, MediaType... supportedMediaTypes) Construct anAbstractHttpMessageConverter
with a default charset and multiple supported media types.protected
AbstractHttpMessageConverter
(MediaType supportedMediaType) Construct anAbstractHttpMessageConverter
with one supported media type.protected
AbstractHttpMessageConverter
(MediaType... supportedMediaTypes) Construct anAbstractHttpMessageConverter
with multiple supported media types. -
Method Summary
Modifier and TypeMethodDescriptionprotected void
addDefaultHeaders
(HttpHeaders headers, T t, @Nullable MediaType contentType) Add default headers to the output message.protected boolean
boolean
This implementation checks if the given class is supported, and if the supported media types include the given media type.protected boolean
Returnstrue
if the given media type includes any of the supported media types.boolean
getContentLength
(T t, @Nullable MediaType contentType) Returns the content length for the given type.Return the default character set, if any.Returns the default content type for the given type.Return the list of media types supported by this converter.final T
read
(Class<? extends T> clazz, HttpInputMessage inputMessage) This implementation simple delegates toreadInternal(Class, HttpInputMessage)
.protected abstract T
readInternal
(Class<? extends T> clazz, HttpInputMessage inputMessage) Abstract template method that reads the actual object.void
setDefaultCharset
(@Nullable Charset defaultCharset) Set the default character set, if any.void
setSupportedMediaTypes
(List<MediaType> supportedMediaTypes) Set the list ofMediaType
objects supported by this converter.protected abstract boolean
Indicates whether the given class is supported by this converter.protected boolean
Indicates whether this message converter can write the given object multiple times.final void
write
(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage) This implementation sets the default headers by callingaddDefaultHeaders(org.springframework.http.HttpHeaders, T, org.springframework.http.MediaType)
, and then callswriteInternal(T, org.springframework.http.HttpOutputMessage)
.protected abstract void
writeInternal
(T t, HttpOutputMessage outputMessage) Abstract template method that writes the actual body.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.springframework.http.converter.HttpMessageConverter
getSupportedMediaTypes
-
Field Details
-
logger
protected final org.apache.commons.logging.Log loggerLogger available to subclasses.
-
-
Constructor Details
-
AbstractHttpMessageConverter
protected AbstractHttpMessageConverter()Construct anAbstractHttpMessageConverter
with no supported media types. -
AbstractHttpMessageConverter
Construct anAbstractHttpMessageConverter
with one supported media type.- Parameters:
supportedMediaType
- the supported media type
-
AbstractHttpMessageConverter
Construct anAbstractHttpMessageConverter
with multiple supported media types.- Parameters:
supportedMediaTypes
- the supported media types
-
AbstractHttpMessageConverter
Construct anAbstractHttpMessageConverter
with a default charset and multiple supported media types.- Parameters:
defaultCharset
- the default character setsupportedMediaTypes
- the supported media types- Since:
- 4.3
-
-
Method Details
-
setSupportedMediaTypes
Set the list ofMediaType
objects supported by this converter. -
getSupportedMediaTypes
Description copied from interface:HttpMessageConverter
Return the list of media types supported by this converter. The list may not apply to every possible target element type and calls to this method should typically be guarded viacanWrite(clazz, null
. The list may also exclude MIME types supported only for a specific class. Alternatively, useHttpMessageConverter.getSupportedMediaTypes(Class)
for a more precise list.- Specified by:
getSupportedMediaTypes
in interfaceHttpMessageConverter<T>
- Returns:
- the list of supported media types
-
setDefaultCharset
Set the default character set, if any.- Since:
- 4.3
-
getDefaultCharset
Return the default character set, if any.- Since:
- 4.3
-
canRead
This implementation checks if the given class is supported, and if the supported media types include the given media type.- Specified by:
canRead
in interfaceHttpMessageConverter<T>
- Parameters:
clazz
- the class to test for readabilitymediaType
- the media type to read (can benull
if not specified); typically the value of aContent-Type
header.- Returns:
true
if readable;false
otherwise
-
canRead
- Parameters:
mediaType
- the media type to read, can benull
if not specified. Typically the value of aContent-Type
header.- Returns:
true
if the supported media types include the media type, or if the media type isnull
-
canWrite
This implementation checks if the given class is supported, and if the supported media types include the given media type.- Specified by:
canWrite
in interfaceHttpMessageConverter<T>
- Parameters:
clazz
- the class to test for writabilitymediaType
- the media type to write (can benull
if not specified); typically the value of anAccept
header.- Returns:
true
if writable;false
otherwise
-
canWrite
Returnstrue
if the given media type includes any of the supported media types.- Parameters:
mediaType
- the media type to write, can benull
if not specified. Typically the value of anAccept
header.- Returns:
true
if the supported media types are compatible with the media type, or if the media type isnull
-
read
public final T read(Class<? extends T> clazz, HttpInputMessage inputMessage) throws IOException, HttpMessageNotReadableException This implementation simple delegates toreadInternal(Class, HttpInputMessage)
. Future implementations might add some default behavior, however.- Specified by:
read
in interfaceHttpMessageConverter<T>
- Parameters:
clazz
- the type of object to return. This type must have previously been passed to thecanRead
method of this interface, which must have returnedtrue
.inputMessage
- the HTTP input message to read from- Returns:
- the converted object
- Throws:
IOException
- in case of I/O errorsHttpMessageNotReadableException
- in case of conversion errors
-
write
public final void write(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage) throws IOException, HttpMessageNotWritableException This implementation sets the default headers by callingaddDefaultHeaders(org.springframework.http.HttpHeaders, T, org.springframework.http.MediaType)
, and then callswriteInternal(T, org.springframework.http.HttpOutputMessage)
.- Specified by:
write
in interfaceHttpMessageConverter<T>
- Parameters:
t
- the object to write to the output message. The type of this object must have previously been passed to thecanWrite
method of this interface, which must have returnedtrue
.contentType
- the content type to use when writing. May benull
to indicate that the default content type of the converter must be used. If notnull
, this media type must have previously been passed to thecanWrite
method of this interface, which must have returnedtrue
.outputMessage
- the message to write to- Throws:
IOException
- in case of I/O errorsHttpMessageNotWritableException
- in case of conversion errors
-
addDefaultHeaders
protected void addDefaultHeaders(HttpHeaders headers, T t, @Nullable MediaType contentType) throws IOException Add default headers to the output message.This implementation delegates to
getDefaultContentType(Object)
if a content type was not provided, set if necessary the default character set, callsgetContentLength(T, org.springframework.http.MediaType)
, and sets the corresponding headers.- Throws:
IOException
- Since:
- 4.2
-
getDefaultContentType
Returns the default content type for the given type. Called whenwrite(T, org.springframework.http.MediaType, org.springframework.http.HttpOutputMessage)
is invoked without a specified content type parameter.By default, this returns the first element of the
supportedMediaTypes
property, if any. Can be overridden in subclasses.- Parameters:
t
- the type to return the content type for- Returns:
- the content type, or
null
if not known - Throws:
IOException
-
getContentLength
Returns the content length for the given type.By default, this returns
null
, meaning that the content length is unknown. Can be overridden in subclasses.- Parameters:
t
- the type to return the content length for- Returns:
- the content length, or
null
if not known - Throws:
IOException
-
supportsRepeatableWrites
Indicates whether this message converter can write the given object multiple times.The default implementation returns
false
.- Parameters:
t
- the object t- Returns:
true
ift
can be written repeatedly;false
otherwise- Since:
- 6.1
-
supports
Indicates whether the given class is supported by this converter.- Parameters:
clazz
- the class to test for support- Returns:
true
if supported;false
otherwise
-
readInternal
protected abstract T readInternal(Class<? extends T> clazz, HttpInputMessage inputMessage) throws IOException, HttpMessageNotReadableException Abstract template method that reads the actual object. Invoked fromread(java.lang.Class<? extends T>, org.springframework.http.HttpInputMessage)
.- Parameters:
clazz
- the type of object to returninputMessage
- the HTTP input message to read from- Returns:
- the converted object
- Throws:
IOException
- in case of I/O errorsHttpMessageNotReadableException
- in case of conversion errors
-
writeInternal
protected abstract void writeInternal(T t, HttpOutputMessage outputMessage) throws IOException, HttpMessageNotWritableException Abstract template method that writes the actual body. Invoked fromwrite(T, org.springframework.http.MediaType, org.springframework.http.HttpOutputMessage)
.- Parameters:
t
- the object to write to the output messageoutputMessage
- the HTTP output message to write to- Throws:
IOException
- in case of I/O errorsHttpMessageNotWritableException
- in case of conversion errors
-