public class AntPathMatcher extends java.lang.Object implements PathMatcher
Part of this mapping code has been kindly borrowed from Apache Ant.
The mapping matches URLs using the following rules:
Some examples:
com/t?st.jsp - matches com/test.jsp but also
com/tast.jsp or com/txst.jspcom/*.jsp - matches all
.jsp files in the com directorycom/**/test.jsp - matches all
test.jsp files underneath the com pathorg/springframework/**/*.jsp
- matches all .jsp files underneath the org/springframework pathorg/**/servlet/bla.jsp - matches org/springframework/servlet/bla.jsp but also
org/springframework/testing/servlet/bla.jsp and org/servlet/bla.jsp| Modifier and Type | Class and Description |
|---|---|
protected static class |
AntPathMatcher.AntPathStringMatcher
Tests whether or not a string matches against a pattern via a
Pattern. |
protected static class |
AntPathMatcher.AntPatternComparator
The default
Comparator implementation returned by
getPatternComparator(String). |
| Modifier and Type | Field and Description |
|---|---|
private static int |
CACHE_TURNOFF_THRESHOLD |
private java.lang.Boolean |
cachePatterns |
static java.lang.String |
DEFAULT_PATH_SEPARATOR
Default path separator: "/"
|
private java.lang.String |
pathSeparator |
(package private) java.util.Map<java.lang.String,AntPathMatcher.AntPathStringMatcher> |
stringMatcherCache |
private boolean |
trimTokens |
private static java.util.regex.Pattern |
VARIABLE_PATTERN |
| Constructor and Description |
|---|
AntPathMatcher() |
| Modifier and Type | Method and Description |
|---|---|
java.lang.String |
combine(java.lang.String pattern1,
java.lang.String pattern2)
Combines two patterns into a new pattern that is returned.
|
protected boolean |
doMatch(java.lang.String pattern,
java.lang.String path,
boolean fullMatch,
java.util.Map<java.lang.String,java.lang.String> uriTemplateVariables)
Actually match the given
path against the given pattern. |
java.lang.String |
extractPathWithinPattern(java.lang.String pattern,
java.lang.String path)
Given a pattern and a full path, determine the pattern-mapped part.
|
java.util.Map<java.lang.String,java.lang.String> |
extractUriTemplateVariables(java.lang.String pattern,
java.lang.String path)
Given a pattern and a full path, extract the URI template variables.
|
java.util.Comparator<java.lang.String> |
getPatternComparator(java.lang.String path)
Given a full path, returns a
Comparator suitable for sorting patterns in order of explicitness. |
protected AntPathMatcher.AntPathStringMatcher |
getStringMatcher(java.lang.String pattern)
Build or retrieve an
AntPathMatcher.AntPathStringMatcher for the given pattern. |
boolean |
isPattern(java.lang.String path)
Does the given
path represent a pattern that can be matched
by an implementation of this interface? |
boolean |
match(java.lang.String pattern,
java.lang.String path)
Match the given
path against the given pattern,
according to this PathMatcher's matching strategy. |
boolean |
matchStart(java.lang.String pattern,
java.lang.String path)
Match the given
path against the corresponding part of the given
pattern, according to this PathMatcher's matching strategy. |
private boolean |
matchStrings(java.lang.String pattern,
java.lang.String str,
java.util.Map<java.lang.String,java.lang.String> uriTemplateVariables)
Tests whether or not a string matches against a pattern.
|
void |
setCachePatterns(boolean cachePatterns)
Specify whether to cache parsed pattern metadata for patterns passed
into this matcher's
match(java.lang.String, java.lang.String) method. |
void |
setPathSeparator(java.lang.String pathSeparator)
Set the path separator to use for pattern parsing.
|
void |
setTrimTokens(boolean trimTokens)
Specify whether to trim tokenized paths and patterns.
|
private java.lang.String |
slashConcat(java.lang.String path1,
java.lang.String path2) |
private static final int CACHE_TURNOFF_THRESHOLD
private static final java.util.regex.Pattern VARIABLE_PATTERN
public static final java.lang.String DEFAULT_PATH_SEPARATOR
private java.lang.String pathSeparator
private boolean trimTokens
private volatile java.lang.Boolean cachePatterns
final java.util.Map<java.lang.String,AntPathMatcher.AntPathStringMatcher> stringMatcherCache
public void setPathSeparator(java.lang.String pathSeparator)
public void setTrimTokens(boolean trimTokens)
true.public void setCachePatterns(boolean cachePatterns)
match(java.lang.String, java.lang.String) method. A value of true
activates an unlimited pattern cache; a value of false turns
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 reoccurring pattern.
getStringMatcher(String)public boolean isPattern(java.lang.String path)
PathMatcherpath represent a pattern that can be matched
by an implementation of this interface?
If the return value is false, then the PathMatcher.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.
isPattern in interface PathMatcherpath - the path String to checktrue if the given path represents a patternpublic boolean match(java.lang.String pattern,
java.lang.String path)
PathMatcherpath against the given pattern,
according to this PathMatcher's matching strategy.match in interface PathMatcherpattern - the pattern to match againstpath - the path String to testtrue if the supplied path matched,
false if it didn'tpublic boolean matchStart(java.lang.String pattern,
java.lang.String path)
PathMatcherpath against the corresponding part of the given
pattern, 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.
matchStart in interface PathMatcherpattern - the pattern to match againstpath - the path String to testtrue if the supplied path matched,
false if it didn'tprotected boolean doMatch(java.lang.String pattern,
java.lang.String path,
boolean fullMatch,
java.util.Map<java.lang.String,java.lang.String> uriTemplateVariables)
path against the given pattern.pattern - the pattern to match againstpath - the path String to testfullMatch - whether a full pattern match is required (else a pattern match
as far as the given base path goes is sufficient)true if the supplied path matched, false if it didn'tprivate boolean matchStrings(java.lang.String pattern,
java.lang.String str,
java.util.Map<java.lang.String,java.lang.String> uriTemplateVariables)
pattern - the pattern to match against (never null)str - the String which must be matched against the pattern (never null)true if the string matches against the pattern, or false otherwiseprotected AntPathMatcher.AntPathStringMatcher getStringMatcher(java.lang.String pattern)
AntPathMatcher.AntPathStringMatcher for 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 reoccurring pattern.
This method may get overridden to implement a custom cache strategy.
pattern - the pattern to match against (never null)null)setCachePatterns(boolean)public java.lang.String extractPathWithinPattern(java.lang.String pattern,
java.lang.String path)
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) returns true for 'pattern' and 'path', but
does not enforce this.
extractPathWithinPattern in interface PathMatcherpattern - the path patternpath - the full path to introspectpath
(never null)public java.util.Map<java.lang.String,java.lang.String> extractUriTemplateVariables(java.lang.String pattern,
java.lang.String path)
PathMatcherFor example: For pattern "/hotels/{hotel}" and path "/hotels/1", this method will return a map containing "hotel"->"1".
extractUriTemplateVariables in interface PathMatcherpattern - the path pattern, possibly containing URI templatespath - the full path to extract template variables frompublic java.lang.String combine(java.lang.String pattern1,
java.lang.String pattern2)
This implementation simply concatenates the two patterns, unless the first pattern
contains a file extension match (such as *.html. In that case, the second pattern
should be included in the first, or an IllegalArgumentException is thrown.
For example:
| Pattern 1 | Pattern 2 | Result |
|---|---|---|
| /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 |
combine in interface PathMatcherpattern1 - the first patternpattern2 - the second patternjava.lang.IllegalArgumentException - when the two patterns cannot be combinedprivate java.lang.String slashConcat(java.lang.String path1,
java.lang.String path2)
public java.util.Comparator<java.lang.String> getPatternComparator(java.lang.String path)
Comparator suitable for sorting patterns in order of explicitness.
The returned Comparator will 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:
/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/2 will be sorted before /hotels/1.
getPatternComparator in interface PathMatcherpath - the full path to use for comparison