Class MappedInterceptor
- All Implemented Interfaces:
HandlerInterceptor
HandlerInterceptor
and uses URL patterns to determine whether
it applies to a given request.
Pattern matching can be done with a PathMatcher
or with a parsed
PathPattern
. The syntax is largely the same with the latter being more
tailored for web usage and more efficient. The choice is driven by the
presence of a resolved
String
lookupPath or a parsed RequestPath
which in turn depends on the HandlerMapping
that matched the current request.
MappedInterceptor
is supported by subclasses of
AbstractHandlerMethodMapping
which detect beans of type MappedInterceptor
and also check if interceptors directly registered with it are of this type.
- Since:
- 3.0
- Author:
- Keith Donald, Rossen Stoyanchev, Brian Clozel
-
Constructor Summary
ConstructorDescriptionMappedInterceptor
(String[] includePatterns, String[] excludePatterns, WebRequestInterceptor interceptor) Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
with aWebRequestInterceptor
as the target.MappedInterceptor
(String[] includePatterns, String[] excludePatterns, HandlerInterceptor interceptor) Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
without a provided parser.MappedInterceptor
(String[] includePatterns, String[] excludePatterns, HandlerInterceptor interceptor, PathPatternParser parser) Create an instance with the given include and exclude patterns along with the target interceptor for the mappings.MappedInterceptor
(String[] includePatterns, WebRequestInterceptor interceptor) Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
with aWebRequestInterceptor
as the target.MappedInterceptor
(String[] includePatterns, HandlerInterceptor interceptor) Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
with include patterns only. -
Method Summary
Modifier and TypeMethodDescriptionvoid
afterCompletion
(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) Callback after completion of request processing, that is, after rendering the view.String[]
Get the exclude path patterns this interceptor is mapped to.String[]
Get the include path patterns this interceptor is mapped to.The targetHandlerInterceptor
to invoke in case of a match.Get the configured PathMatcher.String[]
Deprecated, for removal: This API element is subject to removal in a future version.boolean
matches
(HttpServletRequest request) Check whether this interceptor is mapped to the request.boolean
matches
(String lookupPath, PathMatcher pathMatcher) Deprecated.as of 5.3 in favor ofmatches(HttpServletRequest)
void
postHandle
(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) Interception point after successful execution of a handler.boolean
preHandle
(HttpServletRequest request, HttpServletResponse response, Object handler) Interception point before the execution of a handler.void
setPathMatcher
(PathMatcher pathMatcher) Configure the PathMatcher to use to match URL paths with against include and exclude patterns.
-
Constructor Details
-
MappedInterceptor
public MappedInterceptor(@Nullable String[] includePatterns, @Nullable String[] excludePatterns, HandlerInterceptor interceptor, @Nullable PathPatternParser parser) Create an instance with the given include and exclude patterns along with the target interceptor for the mappings.- Parameters:
includePatterns
- patterns to which requests must match, or null to match all pathsexcludePatterns
- patterns to which requests must not matchinterceptor
- the target interceptorparser
- a parser to use to pre-parse patterns intoPathPattern
; when not provided,PathPatternParser.defaultInstance
is used.- Since:
- 5.3
-
MappedInterceptor
Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
with include patterns only. -
MappedInterceptor
public MappedInterceptor(@Nullable String[] includePatterns, @Nullable String[] excludePatterns, HandlerInterceptor interceptor) Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
without a provided parser. -
MappedInterceptor
Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
with aWebRequestInterceptor
as the target. -
MappedInterceptor
public MappedInterceptor(@Nullable String[] includePatterns, @Nullable String[] excludePatterns, WebRequestInterceptor interceptor) Variant ofMappedInterceptor(String[], String[], HandlerInterceptor, PathPatternParser)
with aWebRequestInterceptor
as the target.
-
-
Method Details
-
getPathPatterns
Deprecated, for removal: This API element is subject to removal in a future version.since 6.1 in favor ofgetIncludePathPatterns()
Get the include path patterns this interceptor is mapped to. -
getIncludePathPatterns
Get the include path patterns this interceptor is mapped to.- Since:
- 6.1
- See Also:
-
getExcludePathPatterns
Get the exclude path patterns this interceptor is mapped to.- Since:
- 6.1
- See Also:
-
getInterceptor
The targetHandlerInterceptor
to invoke in case of a match. -
setPathMatcher
Configure the PathMatcher to use to match URL paths with against include and exclude patterns.This is an advanced property that should be used only when a customized
AntPathMatcher
or a custom PathMatcher is required.By default this is
AntPathMatcher
.Note: Setting
PathMatcher
enforces use of String pattern matching even when a parsedRequestPath
is available. -
getPathMatcher
Get the configured PathMatcher. -
matches
Check whether this interceptor is mapped to the request.The request mapping path is expected to have been resolved externally. See also class-level Javadoc.
- Parameters:
request
- the request to match to- Returns:
true
if the interceptor should be applied to the request
-
matches
Deprecated.as of 5.3 in favor ofmatches(HttpServletRequest)
Determine if there is a match for the given lookup path.- Parameters:
lookupPath
- the current request pathpathMatcher
- a path matcher for path pattern matching- Returns:
true
if the interceptor applies to the given request path
-
preHandle
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception Description copied from interface:HandlerInterceptor
Interception point before the execution of a handler. Called after HandlerMapping determined an appropriate handler object, but before HandlerAdapter invokes the handler.DispatcherServlet processes a handler in an execution chain, consisting of any number of interceptors, with the handler itself at the end. With this method, each interceptor can decide to abort the execution chain, typically sending an HTTP error or writing a custom response.
Note: special considerations apply for asynchronous request processing. For more details see
AsyncHandlerInterceptor
.The default implementation returns
true
.- Specified by:
preHandle
in interfaceHandlerInterceptor
- Parameters:
request
- current HTTP requestresponse
- current HTTP responsehandler
- chosen handler to execute, for type and/or instance evaluation- Returns:
true
if the execution chain should proceed with the next interceptor or the handler itself. Else, DispatcherServlet assumes that this interceptor has already dealt with the response itself.- Throws:
Exception
- in case of errors
-
postHandle
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception Description copied from interface:HandlerInterceptor
Interception point after successful execution of a handler. Called after HandlerAdapter actually invoked the handler, but before the DispatcherServlet renders the view. Can expose additional model objects to the view via the given ModelAndView.DispatcherServlet processes a handler in an execution chain, consisting of any number of interceptors, with the handler itself at the end. With this method, each interceptor can post-process an execution, getting applied in inverse order of the execution chain.
Note: special considerations apply for asynchronous request processing. For more details see
AsyncHandlerInterceptor
.The default implementation is empty.
- Specified by:
postHandle
in interfaceHandlerInterceptor
- Parameters:
request
- current HTTP requestresponse
- current HTTP responsehandler
- the handler (orHandlerMethod
) that started asynchronous execution, for type and/or instance examinationmodelAndView
- theModelAndView
that the handler returned (can also benull
)- Throws:
Exception
- in case of errors
-
afterCompletion
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception Description copied from interface:HandlerInterceptor
Callback after completion of request processing, that is, after rendering the view. Will be called on any outcome of handler execution, thus allows for proper resource cleanup.Note: Will only be called if this interceptor's
preHandle
method has successfully completed and returnedtrue
!As with the
postHandle
method, the method will be invoked on each interceptor in the chain in reverse order, so the first interceptor will be the last to be invoked.Note: special considerations apply for asynchronous request processing. For more details see
AsyncHandlerInterceptor
.The default implementation is empty.
- Specified by:
afterCompletion
in interfaceHandlerInterceptor
- Parameters:
request
- current HTTP requestresponse
- current HTTP responsehandler
- the handler (orHandlerMethod
) that started asynchronous execution, for type and/or instance examinationex
- any exception thrown on handler execution, if any; this does not include exceptions that have been handled through an exception resolver- Throws:
Exception
- in case of errors
-
getIncludePathPatterns()