Class RequestMappingHandlerAdapter
- All Implemented Interfaces:
- Aware,- BeanFactoryAware,- InitializingBean,- ApplicationContextAware,- Ordered,- ServletContextAware,- HandlerAdapter
AbstractHandlerMethodAdapter that supports
 @RequestMapping annotated HandlerMethods.
 Support for custom argument and return value types can be added via
 setCustomArgumentResolvers(java.util.List<org.springframework.web.method.support.HandlerMethodArgumentResolver>) and setCustomReturnValueHandlers(java.util.List<org.springframework.web.method.support.HandlerMethodReturnValueHandler>),
 or alternatively, to re-configure all argument and return value types,
 use setArgumentResolvers(java.util.List<org.springframework.web.method.support.HandlerMethodArgumentResolver>) and setReturnValueHandlers(java.util.List<org.springframework.web.method.support.HandlerMethodReturnValueHandler>).
- Since:
- 3.1
- Author:
- Rossen Stoyanchev, Juergen Hoeller, Sebastien Deleuze
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final ReflectionUtils.MethodFilterMethodFilter that matches@InitBindermethods.static final ReflectionUtils.MethodFilterMethodFilter that matches@ModelAttributemethods.Fields inherited from class org.springframework.web.servlet.support.WebContentGeneratorHEADER_CACHE_CONTROL, METHOD_GET, METHOD_HEAD, METHOD_POSTFields inherited from class org.springframework.context.support.ApplicationObjectSupportloggerFields inherited from interface org.springframework.core.OrderedHIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.protected InitBinderDataBinderFactorycreateDataBinderFactory(List<InvocableHandlerMethod> binderMethods) Template method to create a new InitBinderDataBinderFactory instance.protected ServletInvocableHandlerMethodcreateInvocableHandlerMethod(HandlerMethod handlerMethod) Create aServletInvocableHandlerMethodfrom the givenHandlerMethoddefinition.Return the configured argument resolvers, or possiblynullif not initialized yet viaafterPropertiesSet().protected ConfigurableBeanFactoryReturn the owning factory of this bean instance, ornullif none.Return the custom argument resolvers, ornull.Return the custom return value handlers, ornull.Return the argument resolvers for@InitBindermethods, or possiblynullif not initialized yet viaafterPropertiesSet().protected longgetLastModifiedInternal(HttpServletRequest request, HandlerMethod handlerMethod) This implementation always returns -1.Return the configured message body converters.Return the configuredModelAndViewResolvers, ornull.Return the configured reactive type registry of adapters.Return the configured handlers, or possiblynullif not initialized yet viaafterPropertiesSet().Return the configured WebBindingInitializer, ornullif none.protected ModelAndViewhandleInternal(HttpServletRequest request, HttpServletResponse response, HandlerMethod handlerMethod) Use the given handler method to handle the request.protected ModelAndViewinvokeHandlerMethod(HttpServletRequest request, HttpServletResponse response, HandlerMethod handlerMethod) Invoke theRequestMappinghandler method preparing aModelAndViewif view resolution is required.voidsetArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) Configure the complete list of supported argument types thus overriding the resolvers that would otherwise be configured by default.voidsetAsyncRequestTimeout(long timeout) Specify the amount of time, in milliseconds, before concurrent handling should time out.voidsetBeanFactory(BeanFactory beanFactory) AConfigurableBeanFactoryis expected for resolving expressions in method argument default values.voidsetCacheSecondsForSessionAttributeHandlers(int cacheSecondsForSessionAttributeHandlers) Cache content produced by@SessionAttributesannotated handlers for the given number of seconds.voidsetCallableInterceptors(List<CallableProcessingInterceptor> interceptors) ConfigureCallableProcessingInterceptor's to register on async requests.voidsetContentNegotiationManager(ContentNegotiationManager contentNegotiationManager) Set theContentNegotiationManagerto use to determine requested media types.voidsetCustomArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) Provide resolvers for custom argument types.voidsetCustomReturnValueHandlers(List<HandlerMethodReturnValueHandler> returnValueHandlers) Provide handlers for custom return value types.voidsetDeferredResultInterceptors(List<DeferredResultProcessingInterceptor> interceptors) ConfigureDeferredResultProcessingInterceptor's to register on async requests.voidsetIgnoreDefaultModelOnRedirect(boolean ignoreDefaultModelOnRedirect) Deprecated.as of 6.0 without a replacement; once removed, the default model will always be ignored on redirectvoidsetInitBinderArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) Configure the supported argument types in@InitBindermethods.voidsetMessageConverters(List<HttpMessageConverter<?>> messageConverters) Provide the converters to use in argument resolvers and return value handlers that support reading and/or writing to the body of the request and response.voidsetModelAndViewResolvers(List<ModelAndViewResolver> modelAndViewResolvers) Provide customModelAndViewResolvers.voidsetParameterNameDiscoverer(ParameterNameDiscoverer parameterNameDiscoverer) Set the ParameterNameDiscoverer to use for resolving method parameter names if needed (e.g.voidsetReactiveAdapterRegistry(ReactiveAdapterRegistry reactiveAdapterRegistry) Configure the registry for reactive library types to be supported as return values from controller methods.voidsetRequestBodyAdvice(List<RequestBodyAdvice> requestBodyAdvice) Add one or moreRequestBodyAdviceinstances to intercept the request before it is read and converted for@RequestBodyandHttpEntitymethod arguments.voidsetResponseBodyAdvice(List<ResponseBodyAdvice<?>> responseBodyAdvice) Add one or moreResponseBodyAdviceinstances to intercept the response before@ResponseBodyorResponseEntityreturn values are written to the response body.voidsetReturnValueHandlers(List<HandlerMethodReturnValueHandler> returnValueHandlers) Configure the complete list of supported return value types thus overriding handlers that would otherwise be configured by default.voidsetSessionAttributeStore(SessionAttributeStore sessionAttributeStore) Specify the strategy to store session attributes with.voidsetSynchronizeOnSession(boolean synchronizeOnSession) Set if controller execution should be synchronized on the session, to serialize parallel invocations from the same client.voidsetTaskExecutor(AsyncTaskExecutor taskExecutor) Set the defaultAsyncTaskExecutorto use when a controller method return aCallable.voidsetWebBindingInitializer(WebBindingInitializer webBindingInitializer) Provide a WebBindingInitializer with "global" initialization to apply to every DataBinder instance.protected booleansupportsInternal(HandlerMethod handlerMethod) Always returntruesince any method argument and return value type will be processed in some way.Methods inherited from class org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdaptergetLastModified, getOrder, handle, setOrder, supportsMethods inherited from class org.springframework.web.servlet.support.WebContentGeneratorapplyCacheControl, applyCacheSeconds, applyCacheSeconds, cacheForSeconds, cacheForSeconds, checkAndPrepare, checkRequest, getAllowHeader, getCacheControl, getCacheSeconds, getSupportedMethods, getVaryByRequestHeaders, isAlwaysMustRevalidate, isRequireSession, isUseCacheControlHeader, isUseCacheControlNoStore, isUseExpiresHeader, prepareResponse, preventCaching, setAlwaysMustRevalidate, setCacheControl, setCacheSeconds, setRequireSession, setSupportedMethods, setUseCacheControlHeader, setUseCacheControlNoStore, setUseExpiresHeader, setVaryByRequestHeadersMethods inherited from class org.springframework.web.context.support.WebApplicationObjectSupportgetServletContext, getTempDir, getWebApplicationContext, initApplicationContext, initServletContext, isContextRequired, setServletContextMethods inherited from class org.springframework.context.support.ApplicationObjectSupportgetApplicationContext, getMessageSourceAccessor, initApplicationContext, obtainApplicationContext, requiredContextClass, setApplicationContext
- 
Field Details- 
INIT_BINDER_METHODSMethodFilter that matches@InitBindermethods.
- 
MODEL_ATTRIBUTE_METHODSMethodFilter that matches@ModelAttributemethods.
 
- 
- 
Constructor Details- 
RequestMappingHandlerAdapterpublic RequestMappingHandlerAdapter()
 
- 
- 
Method Details- 
setCustomArgumentResolverspublic void setCustomArgumentResolvers(@Nullable List<HandlerMethodArgumentResolver> argumentResolvers) Provide resolvers for custom argument types. Custom resolvers are ordered after built-in ones. To override the built-in support for argument resolution usesetArgumentResolvers(java.util.List<org.springframework.web.method.support.HandlerMethodArgumentResolver>)instead.
- 
getCustomArgumentResolversReturn the custom argument resolvers, ornull.
- 
setArgumentResolversConfigure the complete list of supported argument types thus overriding the resolvers that would otherwise be configured by default.
- 
getArgumentResolversReturn the configured argument resolvers, or possiblynullif not initialized yet viaafterPropertiesSet().
- 
setInitBinderArgumentResolverspublic void setInitBinderArgumentResolvers(@Nullable List<HandlerMethodArgumentResolver> argumentResolvers) Configure the supported argument types in@InitBindermethods.
- 
getInitBinderArgumentResolversReturn the argument resolvers for@InitBindermethods, or possiblynullif not initialized yet viaafterPropertiesSet().
- 
setCustomReturnValueHandlerspublic void setCustomReturnValueHandlers(@Nullable List<HandlerMethodReturnValueHandler> returnValueHandlers) Provide handlers for custom return value types. Custom handlers are ordered after built-in ones. To override the built-in support for return value handling usesetReturnValueHandlers(java.util.List<org.springframework.web.method.support.HandlerMethodReturnValueHandler>).
- 
getCustomReturnValueHandlersReturn the custom return value handlers, ornull.
- 
setReturnValueHandlerspublic void setReturnValueHandlers(@Nullable List<HandlerMethodReturnValueHandler> returnValueHandlers) Configure the complete list of supported return value types thus overriding handlers that would otherwise be configured by default.
- 
getReturnValueHandlersReturn the configured handlers, or possiblynullif not initialized yet viaafterPropertiesSet().
- 
setModelAndViewResolversProvide customModelAndViewResolvers.Note: This method is available for backwards compatibility only. However, it is recommended to re-write a ModelAndViewResolverasHandlerMethodReturnValueHandler. An adapter between the two interfaces is not possible since theHandlerMethodReturnValueHandler.supportsReturnType(org.springframework.core.MethodParameter)method cannot be implemented. HenceModelAndViewResolvers are limited to always being invoked at the end after all other return value handlers have been given a chance.A HandlerMethodReturnValueHandlerprovides better access to the return type and controller method information and can be ordered freely relative to other return value handlers.
- 
getModelAndViewResolversReturn the configuredModelAndViewResolvers, ornull.
- 
setContentNegotiationManagerSet theContentNegotiationManagerto use to determine requested media types. If not set, the default constructor is used.
- 
setMessageConvertersProvide the converters to use in argument resolvers and return value handlers that support reading and/or writing to the body of the request and response.
- 
getMessageConvertersReturn the configured message body converters.
- 
setRequestBodyAdviceAdd one or moreRequestBodyAdviceinstances to intercept the request before it is read and converted for@RequestBodyandHttpEntitymethod arguments.
- 
setResponseBodyAdviceAdd one or moreResponseBodyAdviceinstances to intercept the response before@ResponseBodyorResponseEntityreturn values are written to the response body.
- 
setWebBindingInitializerProvide a WebBindingInitializer with "global" initialization to apply to every DataBinder instance.
- 
getWebBindingInitializerReturn the configured WebBindingInitializer, ornullif none.
- 
setTaskExecutorSet the defaultAsyncTaskExecutorto use when a controller method return aCallable. Controller methods can override this default on a per-request basis by returning anWebAsyncTask.If your application has controllers with such return types, please configure an AsyncTaskExecutoras the one used by default is not suitable for production under load.
- 
setAsyncRequestTimeoutpublic void setAsyncRequestTimeout(long timeout) Specify the amount of time, in milliseconds, before concurrent handling should time out. In Servlet 3, the timeout begins after the main request processing thread has exited and ends when the request is dispatched again for further processing of the concurrently produced result.If this value is not set, the default timeout of the underlying implementation is used. - Parameters:
- timeout- the timeout value in milliseconds
 
- 
setCallableInterceptorsConfigureCallableProcessingInterceptor's to register on async requests.- Parameters:
- interceptors- the interceptors to register
 
- 
setDeferredResultInterceptorsConfigureDeferredResultProcessingInterceptor's to register on async requests.- Parameters:
- interceptors- the interceptors to register
 
- 
setReactiveAdapterRegistryConfigure the registry for reactive library types to be supported as return values from controller methods.- Since:
- 5.0.5
 
- 
getReactiveAdapterRegistryReturn the configured reactive type registry of adapters.- Since:
- 5.0
 
- 
setIgnoreDefaultModelOnRedirect@Deprecated(since="6.0") public void setIgnoreDefaultModelOnRedirect(boolean ignoreDefaultModelOnRedirect) Deprecated.as of 6.0 without a replacement; once removed, the default model will always be ignored on redirectBy default, the content of the "default" model is used both during rendering and redirect scenarios. Alternatively a controller method can declare aRedirectAttributesargument and use it to provide attributes for a redirect.Setting this flag to trueguarantees the "default" model is never used in a redirect scenario even if a RedirectAttributes argument is not declared. Setting it tofalsemeans the "default" model may be used in a redirect if the controller method doesn't declare a RedirectAttributes argument.As of 6.0, this property is set to trueby default.- See Also:
 
- 
setSessionAttributeStoreSpecify the strategy to store session attributes with. The default isDefaultSessionAttributeStore, storing session attributes in the HttpSession with the same attribute name as in the model.
- 
setCacheSecondsForSessionAttributeHandlerspublic void setCacheSecondsForSessionAttributeHandlers(int cacheSecondsForSessionAttributeHandlers) Cache content produced by@SessionAttributesannotated handlers for the given number of seconds.Possible values are: - -1: no generation of cache-related headers
- 0 (default value): "Cache-Control: no-store" will prevent caching
- 1 or higher: "Cache-Control: max-age=seconds" will ask to cache content; not advised when dealing with session attributes
 In contrast to the "cacheSeconds" property which will apply to all general handlers (but not to @SessionAttributesannotated handlers), this setting will apply to@SessionAttributeshandlers only.
- 
setSynchronizeOnSessionpublic void setSynchronizeOnSession(boolean synchronizeOnSession) Set if controller execution should be synchronized on the session, to serialize parallel invocations from the same client.More specifically, the execution of the handleRequestInternalmethod will get synchronized if this flag is "true". The best available session mutex will be used for the synchronization; ideally, this will be a mutex exposed by HttpSessionMutexListener.The session mutex is guaranteed to be the same object during the entire lifetime of the session, available under the key defined by the SESSION_MUTEX_ATTRIBUTEconstant. It serves as a safe reference to synchronize on for locking on the current session.In many cases, the HttpSession reference itself is a safe mutex as well, since it will always be the same object reference for the same active logical session. However, this is not guaranteed across different servlet containers; the only 100% safe way is a session mutex. 
- 
setParameterNameDiscovererSet the ParameterNameDiscoverer to use for resolving method parameter names if needed (e.g. for default attribute names).Default is a DefaultParameterNameDiscoverer.
- 
setBeanFactoryAConfigurableBeanFactoryis expected for resolving expressions in method argument default values.- Specified by:
- setBeanFactoryin interface- BeanFactoryAware
- Parameters:
- beanFactory- owning BeanFactory (never- null). The bean can immediately call methods on the factory.
- See Also:
 
- 
getBeanFactoryReturn the owning factory of this bean instance, ornullif none.
- 
afterPropertiesSetpublic void afterPropertiesSet()Description copied from interface:InitializingBeanInvoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.This method allows the bean instance to perform validation of its overall configuration and final initialization when all bean properties have been set. - Specified by:
- afterPropertiesSetin interface- InitializingBean
 
- 
supportsInternalAlways returntruesince any method argument and return value type will be processed in some way. A method argument not recognized by any HandlerMethodArgumentResolver is interpreted as a request parameter if it is a simple type, or as a model attribute otherwise. A return value not recognized by any HandlerMethodReturnValueHandler will be interpreted as a model attribute.- Specified by:
- supportsInternalin class- AbstractHandlerMethodAdapter
- Parameters:
- handlerMethod- the handler method to check
- Returns:
- whether this adapter can adapt the given method
 
- 
handleInternal@Nullable protected ModelAndView handleInternal(HttpServletRequest request, HttpServletResponse response, HandlerMethod handlerMethod) throws Exception Description copied from class:AbstractHandlerMethodAdapterUse the given handler method to handle the request.- Specified by:
- handleInternalin class- AbstractHandlerMethodAdapter
- Parameters:
- request- current HTTP request
- response- current HTTP response
- handlerMethod- handler method to use. This object must have previously been passed to the- AbstractHandlerMethodAdapter.supportsInternal(HandlerMethod)this interface, which must have returned- true.
- Returns:
- a ModelAndView object with the name of the view and the required model data,
 or nullif the request has been handled directly
- Throws:
- Exception- in case of errors
 
- 
getLastModifiedInternalThis implementation always returns -1. An@RequestMappingmethod can calculate the lastModified value, callWebRequest.checkNotModified(long), and returnnullif the result of that call istrue.- Specified by:
- getLastModifiedInternalin class- AbstractHandlerMethodAdapter
- Parameters:
- request- current HTTP request
- handlerMethod- handler method to use
- Returns:
- the lastModified value for the given handler
 
- 
invokeHandlerMethod@Nullable protected ModelAndView invokeHandlerMethod(HttpServletRequest request, HttpServletResponse response, HandlerMethod handlerMethod) throws Exception Invoke theRequestMappinghandler method preparing aModelAndViewif view resolution is required.- Throws:
- Exception
- Since:
- 4.2
- See Also:
 
- 
createInvocableHandlerMethodCreate aServletInvocableHandlerMethodfrom the givenHandlerMethoddefinition.- Parameters:
- handlerMethod- the- HandlerMethoddefinition
- Returns:
- the corresponding ServletInvocableHandlerMethod(or custom subclass thereof)
- Since:
- 4.2
 
- 
createDataBinderFactoryprotected InitBinderDataBinderFactory createDataBinderFactory(List<InvocableHandlerMethod> binderMethods) throws Exception Template method to create a new InitBinderDataBinderFactory instance.The default implementation creates a ServletRequestDataBinderFactory. This can be overridden for custom ServletRequestDataBinder subclasses. - Parameters:
- binderMethods-- @InitBindermethods
- Returns:
- the InitBinderDataBinderFactory instance to use
- Throws:
- Exception- in case of invalid state or arguments
 
 
-