Class RouterFunctionMapping
- java.lang.Object
- org.springframework.context.support.ApplicationObjectSupport
- org.springframework.web.context.support.WebApplicationObjectSupport
- org.springframework.web.servlet.handler.AbstractHandlerMapping
- org.springframework.web.servlet.function.support.RouterFunctionMapping
- All Implemented Interfaces:
Aware,BeanNameAware,InitializingBean,ApplicationContextAware,Ordered,ServletContextAware,HandlerMapping
public class RouterFunctionMapping extends AbstractHandlerMapping implements InitializingBean
HandlerMappingimplementation that supportsRouterFunctions.If no
RouterFunctionis provided at construction time, this mapping will detect all router functions in the application context, and consult them in order.- Since:
- 5.2
- Author:
- Arjen Poutsma
Field Summary
Fields inherited from class org.springframework.context.support.ApplicationObjectSupport
logger
Fields inherited from interface org.springframework.web.servlet.HandlerMapping
BEST_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_ATTRIBUTE
Fields inherited from interface org.springframework.core.Ordered
HIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
Constructor Summary
Constructors Constructor Description RouterFunctionMapping()Create an emptyRouterFunctionMapping.RouterFunctionMapping(RouterFunction<?> routerFunction)Create aRouterFunctionMappingwith the givenRouterFunction.
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidafterPropertiesSet()Invoked by the containingBeanFactoryafter it has set all bean properties and satisfiedBeanFactoryAware,ApplicationContextAwareetc.protected ObjectgetHandlerInternal(HttpServletRequest servletRequest)Look up a handler for the given request, returningnullif no specific one is found.RouterFunction<?>getRouterFunction()Return the configuredRouterFunction.voidsetDetectHandlerFunctionsInAncestorContexts(boolean detectHandlerFunctionsInAncestorContexts)Set whether to detect handler functions in ancestor ApplicationContexts.voidsetMessageConverters(List<HttpMessageConverter<?>> messageConverters)voidsetRouterFunction(RouterFunction<?> routerFunction)Set the router function to map to.Methods inherited from class org.springframework.web.servlet.handler.AbstractHandlerMapping
adaptInterceptor, detectMappedInterceptors, extendInterceptors, formatMappingName, getAdaptedInterceptors, getCorsConfiguration, getCorsHandlerExecutionChain, getCorsProcessor, getDefaultHandler, getHandler, getHandlerExecutionChain, getMappedInterceptors, getOrder, getPathMatcher, getUrlPathHelper, hasCorsConfigurationSource, initApplicationContext, initInterceptors, setAlwaysUseFullPath, setBeanName, setCorsConfigurations, setCorsConfigurationSource, setCorsProcessor, setDefaultHandler, setInterceptors, setOrder, setPathMatcher, setRemoveSemicolonContent, setUrlDecode, setUrlPathHelper
Methods inherited from class org.springframework.web.context.support.WebApplicationObjectSupport
getServletContext, getTempDir, getWebApplicationContext, initApplicationContext, initServletContext, isContextRequired, setServletContext
Methods inherited from class org.springframework.context.support.ApplicationObjectSupport
getApplicationContext, getMessageSourceAccessor, obtainApplicationContext, requiredContextClass, setApplicationContext
Constructor Detail
RouterFunctionMapping
public RouterFunctionMapping()
Create an emptyRouterFunctionMapping.If this constructor is used, this mapping will detect all
RouterFunctioninstances available in the application context.
RouterFunctionMapping
public RouterFunctionMapping(RouterFunction<?> routerFunction)
Create aRouterFunctionMappingwith the givenRouterFunction.If this constructor is used, no application context detection will occur.
- Parameters:
routerFunction- the router function to use for mapping
Method Detail
setRouterFunction
public void setRouterFunction(@Nullable RouterFunction<?> routerFunction)
Set the router function to map to.If this property is used, no application context detection will occur.
getRouterFunction
@Nullable public RouterFunction<?> getRouterFunction()
Return the configuredRouterFunction.Note: When router functions are detected from the ApplicationContext, this method may return
nullif invoked prior toafterPropertiesSet().- Returns:
- the router function or
null
setMessageConverters
public void setMessageConverters(List<HttpMessageConverter<?>> messageConverters)
setDetectHandlerFunctionsInAncestorContexts
public void setDetectHandlerFunctionsInAncestorContexts(boolean detectHandlerFunctionsInAncestorContexts)
Set whether to detect handler functions in ancestor ApplicationContexts.Default is "false": Only handler functions in the current ApplicationContext will be detected, i.e. only in the context that this HandlerMapping itself is defined in (typically the current DispatcherServlet's context).
Switch this flag on to detect handler beans in ancestor contexts (typically the Spring root WebApplicationContext) as well.
afterPropertiesSet
public void afterPropertiesSet() throws Exception
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 interfaceInitializingBean- Throws:
Exception- in the event of misconfiguration (such as failure to set an essential property) or if initialization fails for any other reason
getHandlerInternal
@Nullable protected Object getHandlerInternal(HttpServletRequest servletRequest) throws Exception
Description copied from class:AbstractHandlerMappingLook up a handler for the given request, returningnullif no specific one is found. This method is called byAbstractHandlerMapping.getHandler(javax.servlet.http.HttpServletRequest); anullreturn value will lead to the default handler, if one is set.On CORS pre-flight requests this method should return a match not for the pre-flight request but for the expected actual request based on the URL path, the HTTP methods from the "Access-Control-Request-Method" header, and the headers from the "Access-Control-Request-Headers" header thus allowing the CORS configuration to be obtained via
AbstractHandlerMapping.getCorsConfiguration(Object, HttpServletRequest),Note: This method may also return a pre-built
HandlerExecutionChain, combining a handler object with dynamically determined interceptors. Statically specified interceptors will get merged into such an existing chain.- Specified by:
getHandlerInternalin classAbstractHandlerMapping- Parameters:
servletRequest- current HTTP request- Returns:
- the corresponding handler instance, or
nullif none found - Throws:
Exception- if there is an internal error