Class AntPathMatcher
- All Implemented Interfaces:
- PathMatcher
PathMatcher implementation for Ant-style path patterns.
 Part of this mapping code has been kindly borrowed from Apache Ant.
The mapping matches URLs using the following rules:
 
- ?matches one character
- *matches zero or more characters
- **matches zero or more directories in a path
- {spring:[a-z]+}matches the regexp- [a-z]+as a path variable named "spring"
Examples
- com/t?st.jsp— matches- com/test.jspbut also- com/tast.jspor- com/txst.jsp
- com/*.jsp— matches all- .jspfiles in the- comdirectory
- com/**/test.jsp— matches all- test.jspfiles underneath the- compath
- org/springframework/**/*.jsp— matches all- .jspfiles underneath the- org/springframeworkpath
- org/**/servlet/bla.jsp— matches- org/springframework/servlet/bla.jspbut also- org/springframework/testing/servlet/bla.jspand- org/servlet/bla.jsp
- com/{filename:\\w+}.jspwill match- com/test.jspand assign the value- testto the- filenamevariable
Note: a pattern and a path must both be absolute or must both be relative in order for the two to match. Therefore, it is recommended that users of this implementation to sanitize patterns in order to prefix them with "/" as it makes sense in the context in which they're used.
- Since:
- 16.07.2003
- Author:
- Alef Arendsen, Juergen Hoeller, Rob Harrop, Arjen Poutsma, Rossen Stoyanchev, Sam Brannen, Vladislav Kisel
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static classTests whether a string matches against a pattern via aPattern.protected static classThe defaultComparatorimplementation returned bygetPatternComparator(String).
- 
Field SummaryFields
- 
Constructor SummaryConstructorsConstructorDescriptionCreate a new instance with theDEFAULT_PATH_SEPARATOR.AntPathMatcher(String pathSeparator) A convenient, alternative constructor to use with a custom path separator.
- 
Method SummaryModifier and TypeMethodDescriptionCombine two patterns into a new pattern.protected booleanActually match the givenpathagainst the givenpattern.extractPathWithinPattern(String pattern, String path) Given a pattern and a full path, determine the pattern-mapped part.extractUriTemplateVariables(String pattern, String path) Given a pattern and a full path, extract the URI template variables.getPatternComparator(String path) Given a full path, returns aComparatorsuitable for sorting patterns in order of explicitness.protected AntPathMatcher.AntPathStringMatchergetStringMatcher(String pattern) Build or retrieve anAntPathMatcher.AntPathStringMatcherfor the given pattern.booleanDoes the givenpathrepresent a pattern that can be matched by an implementation of this interface?booleanMatch the givenpathagainst the givenpattern, according to this PathMatcher's matching strategy.booleanmatchStart(String pattern, String path) Match the givenpathagainst the corresponding part of the givenpattern, according to this PathMatcher's matching strategy.voidsetCachePatterns(boolean cachePatterns) Specify whether to cache parsed pattern metadata for patterns passed into this matcher'smatch(java.lang.String, java.lang.String)method.voidsetCaseSensitive(boolean caseSensitive) Specify whether to perform pattern matching in a case-sensitive fashion.voidsetPathSeparator(String pathSeparator) Set the path separator to use for pattern parsing.voidsetTrimTokens(boolean trimTokens) Specify whether to trim tokenized paths and patterns.protected String[]tokenizePath(String path) Tokenize the given path into parts, based on this matcher's settings.protected String[]tokenizePattern(String pattern) Tokenize the given path pattern into parts, based on this matcher's settings.
- 
Field Details- 
DEFAULT_PATH_SEPARATORDefault path separator: "/".- See Also:
 
 
- 
- 
Constructor Details- 
AntPathMatcherpublic AntPathMatcher()Create a new instance with theDEFAULT_PATH_SEPARATOR.
- 
AntPathMatcherA convenient, alternative constructor to use with a custom path separator.- Parameters:
- pathSeparator- the path separator to use, must not be- null.
- Since:
- 4.1
 
 
- 
- 
Method Details- 
setPathSeparatorSet the path separator to use for pattern parsing.Default is "/", as in Ant. 
- 
setCaseSensitivepublic void setCaseSensitive(boolean caseSensitive) Specify whether to perform pattern matching in a case-sensitive fashion.Default is true. Switch this tofalsefor case-insensitive matching.- Since:
- 4.2
 
- 
setTrimTokenspublic void setTrimTokens(boolean trimTokens) Specify whether to trim tokenized paths and patterns.Default is false.
- 
setCachePatternspublic void setCachePatterns(boolean cachePatterns) Specify whether to cache parsed pattern metadata for patterns passed into this matcher'smatch(java.lang.String, java.lang.String)method. A value oftrueactivates an unlimited pattern cache; a value offalseturns the pattern cache off completely.Default is for the cache to be on, but with the variant to automatically turn it off when encountering too many patterns to cache at runtime (the threshold is 65536), assuming that arbitrary permutations of patterns are coming in, with little chance for encountering a recurring pattern. - Since:
- 4.0.1
- See Also:
 
- 
isPatternDescription copied from interface:PathMatcherDoes the givenpathrepresent a pattern that can be matched by an implementation of this interface?If the return value is false, then thePathMatcher.match(java.lang.String, java.lang.String)method does not have to be used because direct equality comparisons on the static path Strings will lead to the same result.- Specified by:
- isPatternin interface- PathMatcher
- Parameters:
- path- the path to check
- Returns:
- trueif the given- pathrepresents a pattern
 
- 
matchDescription copied from interface:PathMatcherMatch the givenpathagainst the givenpattern, according to this PathMatcher's matching strategy.- Specified by:
- matchin interface- PathMatcher
- Parameters:
- pattern- the pattern to match against
- path- the path to test
- Returns:
- trueif the supplied- pathmatched,- falseif it didn't
 
- 
matchStartDescription copied from interface:PathMatcherMatch the givenpathagainst the corresponding part of the givenpattern, according to this PathMatcher's matching strategy.Determines whether the pattern at least matches as far as the given base path goes, assuming that a full path may then match as well. - Specified by:
- matchStartin interface- PathMatcher
- Parameters:
- pattern- the pattern to match against
- path- the path to test
- Returns:
- trueif the supplied- pathmatched,- falseif it didn't
 
- 
doMatchprotected boolean doMatch(String pattern, @Nullable String path, boolean fullMatch, @Nullable Map<String, String> uriTemplateVariables) Actually match the givenpathagainst the givenpattern.- Parameters:
- pattern- the pattern to match against
- path- the path to test
- fullMatch- whether a full pattern match is required (else a pattern match as far as the given base path goes is sufficient)
- Returns:
- trueif the supplied- pathmatched,- falseif it didn't
 
- 
tokenizePatternTokenize the given path pattern into parts, based on this matcher's settings.Performs caching based on setCachePatterns(boolean), delegating totokenizePath(String)for the actual tokenization algorithm.- Parameters:
- pattern- the pattern to tokenize
- Returns:
- the tokenized pattern parts
 
- 
tokenizePathTokenize the given path into parts, based on this matcher's settings.- Parameters:
- path- the path to tokenize
- Returns:
- the tokenized path parts
 
- 
getStringMatcherBuild or retrieve anAntPathMatcher.AntPathStringMatcherfor the given pattern.The default implementation checks this AntPathMatcher's internal cache (see setCachePatterns(boolean)), creating a new AntPathStringMatcher instance if no cached copy is found.When encountering too many patterns to cache at runtime (the threshold is 65536), it turns the default cache off, assuming that arbitrary permutations of patterns are coming in, with little chance for encountering a recurring pattern. This method may be overridden to implement a custom cache strategy. - Parameters:
- pattern- the pattern to match against (never- null)
- Returns:
- a corresponding AntPathStringMatcher (never null)
- See Also:
 
- 
extractPathWithinPatternGiven a pattern and a full path, determine the pattern-mapped part.For example: - '/docs/cvs/commit.html' and '/docs/cvs/commit.html→ ''
- '/docs/*' and '/docs/cvs/commit→ 'cvs/commit'
- '/docs/cvs/*.html' and '/docs/cvs/commit.html→ 'commit.html'
- '/docs/**' and '/docs/cvs/commit→ 'cvs/commit'
- '/docs/**\/*.html' and '/docs/cvs/commit.html→ 'cvs/commit.html'
- '/*.html' and '/docs/cvs/commit.html→ 'docs/cvs/commit.html'
- '*.html' and '/docs/cvs/commit.html→ '/docs/cvs/commit.html'
- '*' and '/docs/cvs/commit.html→ '/docs/cvs/commit.html'
 Assumes that match(java.lang.String, java.lang.String)returnstruefor 'pattern' and 'path', but does not enforce this.- Specified by:
- extractPathWithinPatternin interface- PathMatcher
- Parameters:
- pattern- the path pattern
- path- the full path to introspect
- Returns:
- the pattern-mapped part of the given path(nevernull)
 
- '
- 
extractUriTemplateVariablesDescription copied from interface:PathMatcherGiven a pattern and a full path, extract the URI template variables. URI template variables are expressed through curly brackets ('{' and '}').For example: For pattern "/hotels/{hotel}" and path "/hotels/1", this method will return a map containing "hotel" → "1". - Specified by:
- extractUriTemplateVariablesin interface- PathMatcher
- Parameters:
- pattern- the path pattern, possibly containing URI templates
- path- the full path to extract template variables from
- Returns:
- a map, containing variable names as keys; variables values as values
 
- 
combineCombine two patterns into a new pattern.This implementation simply concatenates the two patterns, unless the first pattern contains a file extension match (e.g., *.html). In that case, the second pattern will be merged into the first. Otherwise, anIllegalArgumentExceptionwill be thrown.ExamplesPattern 1 Pattern 2 Result nullnull/hotels null/hotels null/hotels /hotels /hotels /bookings /hotels/bookings /hotels bookings /hotels/bookings /hotels/* /bookings /hotels/bookings /hotels/** /bookings /hotels/**/bookings /hotels {hotel} /hotels/{hotel} /hotels/* {hotel} /hotels/{hotel} /hotels/** {hotel} /hotels/**/{hotel} /*.html /hotels.html /hotels.html /*.html /hotels /hotels.html /*.html /*.txt IllegalArgumentException- Specified by:
- combinein interface- PathMatcher
- Parameters:
- pattern1- the first pattern
- pattern2- the second pattern
- Returns:
- the combination of the two patterns
- Throws:
- IllegalArgumentException- if the two patterns cannot be combined
 
- 
getPatternComparatorGiven a full path, returns aComparatorsuitable for sorting patterns in order of explicitness.This Comparatorwill sort a list so that more specific patterns (without URI templates or wild cards) come before generic patterns. So given a list with the following patterns, the returned comparator will sort this list so that the order will be as indicated.- /hotels/new
- /hotels/{hotel}
- /hotels/*
 The full path given as parameter is used to test for exact matches. So when the given path is /hotels/2, the pattern/hotels/2will be sorted before/hotels/1.- Specified by:
- getPatternComparatorin interface- PathMatcher
- Parameters:
- path- the full path to use for comparison
- Returns:
- a comparator capable of sorting patterns in order of explicitness
 
 
-