Class IntegrationRequestMappingHandlerMapping
- All Implemented Interfaces:
- EventListener,- Aware,- BeanNameAware,- BeanPostProcessor,- DestructionAwareBeanPostProcessor,- InitializingBean,- ApplicationContextAware,- ApplicationListener<ContextRefreshedEvent>,- EmbeddedValueResolverAware,- Ordered,- ServletContextAware,- MatchableHandlerMapping,- HandlerMapping
HandlerMapping implementation that
 detects and registers RequestMappingInfos for
 HttpRequestHandlingEndpointSupport from a Spring Integration HTTP configuration
 of <inbound-channel-adapter/> and <inbound-gateway/> elements.
 
 This class is automatically configured as a bean in the application context during the
 parsing phase of the <inbound-channel-adapter/> and <inbound-gateway/>
 elements, if there is none registered, yet. However it can be configured as a regular
 bean with appropriate configuration for RequestMappingHandlerMapping.
 It is recommended to have only one similar bean in the application context using the 'id'
 HttpContextUtils.HANDLER_MAPPING_BEAN_NAME.
 
 In most cases, Spring MVC offers to configure Request Mapping via
 org.springframework.stereotype.Controller and
 RequestMapping.
 That's why Spring MVC's Handler Mapping infrastructure relies on
 HandlerMethod, as different methods at the same
 org.springframework.stereotype.Controller user-class may have their own
 RequestMapping.
 On the other side, all Spring Integration HTTP Inbound Endpoints are configured on
 the basis of the same BaseHttpInboundEndpoint class and there is no
 single RequestMappingInfo configuration without
 HandlerMethod in Spring MVC.
 Accordingly IntegrationRequestMappingHandlerMapping is a
 HandlerMapping
 compromise implementation between method-level annotations and component-level
 (e.g. Spring Integration XML) configurations.
 
 Starting with version 5.1, this class implements DestructionAwareBeanPostProcessor to
 register HTTP endpoints at runtime for dynamically declared beans, e.g. via
 IntegrationFlowContext, and unregister
 them during the BaseHttpInboundEndpoint destruction.
 This class extends the Spring MVC RequestMappingHandlerMapping class, inheriting
 most of its logic, especially RequestMappingInfoHandlerMapping.handleNoMatch(java.util.Set, String, HttpServletRequest),
 which throws a specific 4xx error for the HTTP response, when mapping doesn't match
 for some reason, preventing calls to any remaining mapping handlers in the application context.
 For this reason, configuring the same path for both Spring Integration and
 Spring MVC request mappings (e.g. `POST` in one and `GET` in the other) is not supported;
 the MVC mapping will not be found.
- Since:
- 3.0
- Author:
- Artem Bilan, Gary Russell
- See Also:
- 
Field SummaryFields inherited from class org.springframework.web.servlet.handler.AbstractHandlerMappingmappingsLoggerFields inherited from class org.springframework.context.support.ApplicationObjectSupportloggerFields inherited from interface org.springframework.web.servlet.HandlerMappingBEST_MATCHING_HANDLER_ATTRIBUTE, BEST_MATCHING_PATTERN_ATTRIBUTE, INTROSPECT_TYPE_LEVEL_MAPPING, LOOKUP_PATH, MATRIX_VARIABLES_ATTRIBUTE, PATH_WITHIN_HANDLER_MAPPING_ATTRIBUTE, PRODUCIBLE_MEDIA_TYPES_ATTRIBUTE, URI_TEMPLATE_VARIABLES_ATTRIBUTEFields inherited from interface org.springframework.core.OrderedHIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidprotected voiddetectHandlerMethods(Object handlerArg) protected CorsConfigurationgetCorsConfiguration(Object handler, javax.servlet.http.HttpServletRequest request) protected HandlerExecutionChaingetHandlerExecutionChain(Object handlerArg, javax.servlet.http.HttpServletRequest request) protected CorsConfigurationinitCorsConfiguration(Object handler, Method method, RequestMappingInfo mappingInfo) protected booleanvoidHttpRequestHandlingEndpointSupports may depend on auto-createdrequestChannels, so MVC Handlers detection should be postponed as late as possible.voidpostProcessBeforeDestruction(Object bean, String beanName) postProcessBeforeInitialization(Object bean, String beanName) booleanrequiresDestruction(Object bean) Methods inherited from class org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMappingcreateRequestMappingInfo, getBuilderConfiguration, getContentNegotiationManager, getCustomMethodCondition, getCustomTypeCondition, getFileExtensions, getMappingForMethod, getPathPrefixes, match, registerHandlerMethod, registerMapping, resolveEmbeddedValuesInPatterns, setContentNegotiationManager, setEmbeddedValueResolver, setPathPrefixes, setUseRegisteredSuffixPatternMatch, setUseSuffixPatternMatch, setUseTrailingSlashMatch, useRegisteredSuffixPatternMatch, useSuffixPatternMatch, useTrailingSlashMatchMethods inherited from class org.springframework.web.servlet.mvc.method.RequestMappingInfoHandlerMappinggetDirectPaths, getHandlerInternal, getMappingComparator, getMappingPathPatterns, getMatchingMapping, handleMatch, handleNoMatchMethods inherited from class org.springframework.web.servlet.handler.AbstractHandlerMethodMappingcreateHandlerMethod, getCandidateBeanNames, getHandlerMethods, getHandlerMethodsForMappingName, getNamingStrategy, handlerMethodsInitialized, hasCorsConfigurationSource, initHandlerMethods, lookupHandlerMethod, processCandidateBean, setDetectHandlerMethodsInAncestorContexts, setHandlerMethodMappingNamingStrategy, setPatternParser, unregisterMappingMethods inherited from class org.springframework.web.servlet.handler.AbstractHandlerMappingadaptInterceptor, detectMappedInterceptors, extendInterceptors, formatMappingName, getAdaptedInterceptors, getCorsConfigurationSource, getCorsHandlerExecutionChain, getCorsProcessor, getDefaultHandler, getHandler, getMappedInterceptors, getOrder, getPathMatcher, getPatternParser, getUrlPathHelper, initApplicationContext, initInterceptors, initLookupPath, setAlwaysUseFullPath, setBeanName, setCorsConfigurations, setCorsConfigurationSource, setCorsProcessor, setDefaultHandler, setInterceptors, setOrder, setPathMatcher, setRemoveSemicolonContent, setUrlDecode, setUrlPathHelper, usesPathPatternsMethods inherited from class org.springframework.web.context.support.WebApplicationObjectSupportgetServletContext, getTempDir, getWebApplicationContext, initApplicationContext, initServletContext, isContextRequired, setServletContextMethods inherited from class org.springframework.context.support.ApplicationObjectSupportgetApplicationContext, getMessageSourceAccessor, obtainApplicationContext, requiredContextClass, setApplicationContextMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.beans.factory.config.BeanPostProcessorpostProcessAfterInitializationMethods inherited from interface org.springframework.web.servlet.HandlerMappinggetHandler, usesPathPatternsMethods inherited from interface org.springframework.web.servlet.handler.MatchableHandlerMappinggetPatternParser
- 
Constructor Details- 
IntegrationRequestMappingHandlerMappingpublic IntegrationRequestMappingHandlerMapping()
 
- 
- 
Method Details- 
postProcessBeforeInitialization- Specified by:
- postProcessBeforeInitializationin interface- BeanPostProcessor
- Throws:
- BeansException
 
- 
postProcessBeforeDestruction- Specified by:
- postProcessBeforeDestructionin interface- DestructionAwareBeanPostProcessor
- Throws:
- BeansException
 
- 
requiresDestruction- Specified by:
- requiresDestructionin interface- DestructionAwareBeanPostProcessor
 
- 
isHandler- Overrides:
- isHandlerin class- RequestMappingHandlerMapping
 
- 
getHandlerExecutionChainprotected HandlerExecutionChain getHandlerExecutionChain(Object handlerArg, javax.servlet.http.HttpServletRequest request) - Overrides:
- getHandlerExecutionChainin class- AbstractHandlerMapping
 
- 
getCorsConfigurationprotected CorsConfiguration getCorsConfiguration(Object handler, javax.servlet.http.HttpServletRequest request) - Overrides:
- getCorsConfigurationin class- AbstractHandlerMethodMapping<RequestMappingInfo>
 
- 
detectHandlerMethods- Overrides:
- detectHandlerMethodsin class- AbstractHandlerMethodMapping<RequestMappingInfo>
 
- 
initCorsConfigurationprotected CorsConfiguration initCorsConfiguration(Object handler, Method method, RequestMappingInfo mappingInfo) - Overrides:
- initCorsConfigurationin class- RequestMappingHandlerMapping
 
- 
onApplicationEventHttpRequestHandlingEndpointSupports may depend on auto-createdrequestChannels, so MVC Handlers detection should be postponed as late as possible.- Specified by:
- onApplicationEventin interface- ApplicationListener<ContextRefreshedEvent>
- See Also:
 
- 
afterPropertiesSetpublic void afterPropertiesSet()- Specified by:
- afterPropertiesSetin interface- InitializingBean
- Overrides:
- afterPropertiesSetin class- RequestMappingHandlerMapping
 
 
-