public abstract class AbstractMessageConverterMethodArgumentResolver extends Object implements HandlerMethodArgumentResolver
HttpMessageConverter
s.Modifier and Type | Field and Description |
---|---|
protected List<MediaType> |
allSupportedMediaTypes |
protected Log |
logger |
protected List<HttpMessageConverter<?>> |
messageConverters |
Constructor and Description |
---|
AbstractMessageConverterMethodArgumentResolver(List<HttpMessageConverter<?>> converters)
Basic constructor with converters only.
|
AbstractMessageConverterMethodArgumentResolver(List<HttpMessageConverter<?>> converters,
List<Object> requestResponseBodyAdvice)
Constructor with converters and
Request~ and ResponseBodyAdvice . |
Modifier and Type | Method and Description |
---|---|
protected ServletServerHttpRequest |
createInputMessage(NativeWebRequest webRequest)
Create a new
HttpInputMessage from the given NativeWebRequest . |
protected org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyAdviceChain |
getAdvice()
Return the configured
RequestBodyAdvice and
RequestBodyAdvice where each instance may be wrapped as a
ControllerAdviceBean . |
protected boolean |
isBindExceptionRequired(WebDataBinder binder,
MethodParameter methodParam)
Whether to raise a fatal bind exception on validation errors.
|
protected <T> Object |
readWithMessageConverters(HttpInputMessage inputMessage,
MethodParameter param,
Type targetType)
Create the method argument value of the expected parameter type by reading
from the given HttpInputMessage.
|
protected <T> Object |
readWithMessageConverters(NativeWebRequest webRequest,
MethodParameter methodParam,
Type paramType)
Create the method argument value of the expected parameter type by
reading from the given request.
|
protected void |
validateIfApplicable(WebDataBinder binder,
MethodParameter methodParam)
Validate the request part if applicable.
|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
resolveArgument, supportsParameter
protected final Log logger
protected final List<HttpMessageConverter<?>> messageConverters
public AbstractMessageConverterMethodArgumentResolver(List<HttpMessageConverter<?>> converters)
public AbstractMessageConverterMethodArgumentResolver(List<HttpMessageConverter<?>> converters, List<Object> requestResponseBodyAdvice)
Request~
and ResponseBodyAdvice
.protected org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyAdviceChain getAdvice()
RequestBodyAdvice
and
RequestBodyAdvice
where each instance may be wrapped as a
ControllerAdviceBean
.protected <T> Object readWithMessageConverters(NativeWebRequest webRequest, MethodParameter methodParam, Type paramType) throws IOException, HttpMediaTypeNotSupportedException, HttpMessageNotReadableException
T
- the expected type of the argument value to be createdwebRequest
- the current requestmethodParam
- the method argumentparamType
- the type of the argument value to be createdIOException
- if the reading from the request failsHttpMediaTypeNotSupportedException
- if no suitable message converter is foundHttpMessageNotReadableException
protected <T> Object readWithMessageConverters(HttpInputMessage inputMessage, MethodParameter param, Type targetType) throws IOException, HttpMediaTypeNotSupportedException, HttpMessageNotReadableException
T
- the expected type of the argument value to be createdinputMessage
- the HTTP input message representing the current requestparam
- the method parameter descriptor (may be null
)targetType
- the target type, not necessarily the same as the method
parameter type, e.g. for HttpEntity<String>
.IOException
- if the reading from the request failsHttpMediaTypeNotSupportedException
- if no suitable message converter is foundHttpMessageNotReadableException
protected ServletServerHttpRequest createInputMessage(NativeWebRequest webRequest)
HttpInputMessage
from the given NativeWebRequest
.webRequest
- the web request to create an input message fromprotected void validateIfApplicable(WebDataBinder binder, MethodParameter methodParam)
The default implementation checks for @javax.validation.Valid
,
Spring's Validated
,
and custom annotations whose name starts with "Valid".
binder
- the DataBinder to be usedmethodParam
- the method parameterisBindExceptionRequired(org.springframework.web.bind.WebDataBinder, org.springframework.core.MethodParameter)
protected boolean isBindExceptionRequired(WebDataBinder binder, MethodParameter methodParam)
binder
- the data binder used to perform data bindingmethodParam
- the method argumenttrue
if the next method argument is not of type Errors