Class AbstractUrlHandlerMapping
- All Implemented Interfaces:
Aware
,BeanNameAware
,ApplicationContextAware
,Ordered
,ServletContextAware
,MatchableHandlerMapping
,HandlerMapping
- Direct Known Subclasses:
AbstractDetectingUrlHandlerMapping
,SimpleUrlHandlerMapping
HandlerMapping
implementations.
Supports literal matches and pattern matches such as "/test/*", "/test/**",
and others. For details on pattern syntax refer to PathPattern
when
parsed patterns are enabled
or see
AntPathMatcher
otherwise. The syntax is largely the same but the
PathPattern
syntax is more tailored for web applications, and its
implementation is more efficient.
All path patterns are checked in order to find the most exact match for the current request path where the "most exact" is the longest path pattern that matches the current request path.
- Since:
- 16.04.2003
- Author:
- Juergen Hoeller, Arjen Poutsma
-
Field Summary
Fields inherited from class org.springframework.web.servlet.handler.AbstractHandlerMapping
mappingsLogger
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
-
Method Summary
Modifier and TypeMethodDescriptionprotected Object
buildPathExposingHandler
(Object rawHandler, String bestMatchingPattern, String pathWithinMapping, Map<String, String> uriTemplateVariables) Build a handler object for the given raw handler, exposing the actual handler, theHandlerMapping.PATH_WITHIN_HANDLER_MAPPING_ATTRIBUTE
, as well as theHandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE
before executing the handler.protected void
exposePathWithinMapping
(String bestMatchingPattern, String pathWithinMapping, HttpServletRequest request) Expose the path within the current mapping as request attribute.protected void
exposeUriTemplateVariables
(Map<String, String> uriTemplateVariables, HttpServletRequest request) Expose the URI templates variables as request attribute.protected Object
getHandlerInternal
(HttpServletRequest request) Look up a handler for the URL path of the given request.Return the handler mappings as a read-only Map, with the registered path or pattern as key and the handler object (or handler bean name in case of a lazy-init handler), as value.final Map<PathPattern,
Object> Identical togetHandlerMap()
but populated when parsed patterns areenabled
; otherwise empty.Return the root handler for this handler mapping (registered for "/"), ornull
if none.protected Object
lookupHandler
(String lookupPath, HttpServletRequest request) Look up a handler instance for the given URL path.protected Object
lookupHandler
(RequestPath path, String lookupPath, HttpServletRequest request) Look up a handler instance for the given URL path.match
(HttpServletRequest request, String pattern) Determine whether the request matches the given pattern.void
registerHandler
(String[] urlPaths, String beanName) Register the specified handler for the given URL paths.void
registerHandler
(String urlPath, Object handler) Register the specified handler for the given URL path.void
setLazyInitHandlers
(boolean lazyInitHandlers) Set whether to lazily initialize handlers.void
setPatternParser
(PathPatternParser patternParser) Set thePathPatternParser
to parsepatterns
with for URL path matching.void
setRootHandler
(Object rootHandler) Set the root handler for this handler mapping, that is, the handler to be registered for the root path ("/").void
setUseTrailingSlashMatch
(boolean useTrailingSlashMatch) Deprecated.protected boolean
Indicates whether this handler mapping support type-level mappings.void
unregisterHandler
(String urlPath) Remove the mapping for the handler registered for the given URL path.boolean
Whether to match to URLs irrespective of the presence of a trailing slash.protected void
validateHandler
(Object handler, HttpServletRequest request) Validate the given handler against the current request.Methods inherited from class org.springframework.web.servlet.handler.AbstractHandlerMapping
adaptInterceptor, detectMappedInterceptors, extendInterceptors, formatMappingName, getAdaptedInterceptors, getCorsConfiguration, getCorsConfigurationSource, getCorsHandlerExecutionChain, getCorsProcessor, getDefaultHandler, getHandler, getHandlerExecutionChain, getMappedInterceptors, getOrder, getPathMatcher, getPatternParser, getUrlPathHelper, hasCorsConfigurationSource, initApplicationContext, initInterceptors, initLookupPath, setAlwaysUseFullPath, setBeanName, setCorsConfigurations, setCorsConfigurationSource, setCorsProcessor, setDefaultHandler, setInterceptors, setOrder, setPathMatcher, setRemoveSemicolonContent, setUrlDecode, setUrlPathHelper, usesPathPatterns
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
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.springframework.web.servlet.HandlerMapping
getHandler, usesPathPatterns
Methods inherited from interface org.springframework.web.servlet.handler.MatchableHandlerMapping
getPatternParser
-
Constructor Details
-
AbstractUrlHandlerMapping
public AbstractUrlHandlerMapping()
-
-
Method Details
-
setPatternParser
Description copied from class:AbstractHandlerMapping
Set thePathPatternParser
to parsepatterns
with for URL path matching. Parsed patterns provide a more modern and efficient alternative to String path matching viaAntPathMatcher
.Note: This property is mutually exclusive with the below properties, all of which are not necessary for parsed patterns and are ignored when a
PathPatternParser
is available:AbstractHandlerMapping.setAlwaysUseFullPath(boolean)
-- parsed patterns always use the full path and consider the servletPath only when a Servlet is mapped by path prefix.AbstractHandlerMapping.setRemoveSemicolonContent(boolean)
-- parsed patterns always ignore semicolon content for path matching purposes, but path parameters remain available for use in controllers via@MatrixVariable
.AbstractHandlerMapping.setUrlDecode(boolean)
-- parsed patterns match one decoded path segment at a time and therefore don't need to decode the full path.AbstractHandlerMapping.setUrlPathHelper(org.springframework.web.util.UrlPathHelper)
-- for parsed patterns, the request path is parsed once inDispatcherServlet
or inServletRequestPathFilter
usingServletRequestPathUtils
and cached in a request attribute.AbstractHandlerMapping.setPathMatcher(org.springframework.util.PathMatcher)
-- a parsed patterns encapsulates the logic for path matching and does need aPathMatcher
.
By default, as of 6.0, this is set to a
PathPatternParser
instance with default settings and therefore use of parsed patterns is enabled. Set this tonull
to switch to String path matching viaAntPathMatcher
instead.- Overrides:
setPatternParser
in classAbstractHandlerMapping
- Parameters:
patternParser
- the parser to use
-
setRootHandler
Set the root handler for this handler mapping, that is, the handler to be registered for the root path ("/").Default is
null
, indicating no root handler. -
getRootHandler
Return the root handler for this handler mapping (registered for "/"), ornull
if none. -
setUseTrailingSlashMatch
Deprecated.as of 6.0, seePathPatternParser.setMatchOptionalTrailingSeparator(boolean)
Whether to match to URLs irrespective of the presence of a trailing slash. If enabled a URL pattern such as "/users" also matches to "/users/".The default value is
false
. -
useTrailingSlashMatch
public boolean useTrailingSlashMatch()Whether to match to URLs irrespective of the presence of a trailing slash. -
setLazyInitHandlers
public void setLazyInitHandlers(boolean lazyInitHandlers) Set whether to lazily initialize handlers. Only applicable to singleton handlers, as prototypes are always lazily initialized. Default is "false", as eager initialization allows for more efficiency through referencing the controller objects directly.If you want to allow your controllers to be lazily initialized, make them "lazy-init" and set this flag to true. Just making them "lazy-init" will not work, as they are initialized through the references from the handler mapping in this case.
-
registerHandler
public void registerHandler(String[] urlPaths, String beanName) throws BeansException, IllegalStateException Register the specified handler for the given URL paths.- Parameters:
urlPaths
- the URLs that the bean should be mapped tobeanName
- the name of the handler bean- Throws:
BeansException
- if the handler couldn't be registeredIllegalStateException
- if there is a conflicting handler registered
-
registerHandler
public void registerHandler(String urlPath, Object handler) throws BeansException, IllegalStateException Register the specified handler for the given URL path.- Parameters:
urlPath
- the URL the bean should be mapped tohandler
- the handler instance or handler bean name String (a bean name will automatically be resolved into the corresponding handler bean)- Throws:
BeansException
- if the handler couldn't be registeredIllegalStateException
- if there is a conflicting handler registered
-
unregisterHandler
Remove the mapping for the handler registered for the given URL path.- Parameters:
urlPath
- the mapping to remove
-
getHandlerInternal
Look up a handler for the URL path of the given request.- Specified by:
getHandlerInternal
in classAbstractHandlerMapping
- Parameters:
request
- current HTTP request- Returns:
- the handler instance, or
null
if none found - Throws:
Exception
- if there is an internal error
-
lookupHandler
@Nullable protected Object lookupHandler(RequestPath path, String lookupPath, HttpServletRequest request) throws Exception Look up a handler instance for the given URL path. This method is used when parsedPathPattern
s areenabled
.- Parameters:
path
- the parsed RequestPathlookupPath
- the String lookupPath for checking direct hitsrequest
- current HTTP request- Returns:
- a matching handler, or
null
if not found - Throws:
Exception
- Since:
- 5.3
-
lookupHandler
@Nullable protected Object lookupHandler(String lookupPath, HttpServletRequest request) throws Exception Look up a handler instance for the given URL path. This method is used when String pattern matching withPathMatcher
is in use.- Parameters:
lookupPath
- the path to match patterns againstrequest
- current HTTP request- Returns:
- a matching handler, or
null
if not found - Throws:
Exception
- See Also:
-
validateHandler
Validate the given handler against the current request.The default implementation is empty. Can be overridden in subclasses, for example to enforce specific preconditions expressed in URL mappings.
- Parameters:
handler
- the handler object to validaterequest
- current HTTP request- Throws:
Exception
- if validation failed
-
buildPathExposingHandler
protected Object buildPathExposingHandler(Object rawHandler, String bestMatchingPattern, String pathWithinMapping, @Nullable Map<String, String> uriTemplateVariables) Build a handler object for the given raw handler, exposing the actual handler, theHandlerMapping.PATH_WITHIN_HANDLER_MAPPING_ATTRIBUTE
, as well as theHandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE
before executing the handler.The default implementation builds a
HandlerExecutionChain
with a special interceptor that exposes the path attribute and URI template variables- Parameters:
rawHandler
- the raw handler to exposepathWithinMapping
- the path to expose before executing the handleruriTemplateVariables
- the URI template variables, can benull
if no variables found- Returns:
- the final handler object
-
exposePathWithinMapping
protected void exposePathWithinMapping(String bestMatchingPattern, String pathWithinMapping, HttpServletRequest request) Expose the path within the current mapping as request attribute.- Parameters:
pathWithinMapping
- the path within the current mappingrequest
- the request to expose the path to- See Also:
-
exposeUriTemplateVariables
protected void exposeUriTemplateVariables(Map<String, String> uriTemplateVariables, HttpServletRequest request) Expose the URI templates variables as request attribute.- Parameters:
uriTemplateVariables
- the URI template variablesrequest
- the request to expose the path to- See Also:
-
match
Description copied from interface:MatchableHandlerMapping
Determine whether the request matches the given pattern. Use this method whenMatchableHandlerMapping.getPatternParser()
returnsnull
which means that theHandlerMapping
is using String pattern matching.- Specified by:
match
in interfaceMatchableHandlerMapping
- Parameters:
request
- the current requestpattern
- the pattern to match- Returns:
- the result from request matching, or
null
if none
-
getHandlerMap
Return the handler mappings as a read-only Map, with the registered path or pattern as key and the handler object (or handler bean name in case of a lazy-init handler), as value. -
getPathPatternHandlerMap
Identical togetHandlerMap()
but populated when parsed patterns areenabled
; otherwise empty.- Since:
- 5.3
-
supportsTypeLevelMappings
protected boolean supportsTypeLevelMappings()Indicates whether this handler mapping support type-level mappings. Default tofalse
.
-
PathPatternParser.setMatchOptionalTrailingSeparator(boolean)