public class AntPathMatcher
extends java.lang.Object
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 | Field and Description |
|---|---|
static java.lang.String |
DEFAULT_PATH_SEPARATOR
Default path separator: "/"
|
| Constructor and Description |
|---|
AntPathMatcher() |
| Modifier and Type | Method and Description |
|---|---|
protected boolean |
doMatch(java.lang.String pattern,
java.lang.String path,
boolean fullMatch)
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.
|
boolean |
isPattern(java.lang.String path) |
boolean |
match(java.lang.String pattern,
java.lang.String path) |
boolean |
matchStart(java.lang.String pattern,
java.lang.String path) |
void |
setPathSeparator(java.lang.String pathSeparator)
Set the path separator to use for pattern parsing.
|
static java.lang.String[] |
tokenizeToStringArray(java.lang.String str,
java.lang.String delimiters)
Tokenize the given String into a String array via a StringTokenizer.
|
static java.lang.String[] |
tokenizeToStringArray(java.lang.String str,
java.lang.String delimiters,
boolean trimTokens,
boolean ignoreEmptyTokens)
Tokenize the given String into a String array via a StringTokenizer.
|
static java.lang.String[] |
toStringArray(java.util.Collection collection)
Copy the given Collection into a String array.
|
public static final java.lang.String DEFAULT_PATH_SEPARATOR
public void setPathSeparator(java.lang.String pathSeparator)
public boolean isPattern(java.lang.String path)
public boolean match(java.lang.String pattern,
java.lang.String path)
public boolean matchStart(java.lang.String pattern,
java.lang.String path)
protected boolean doMatch(java.lang.String pattern,
java.lang.String path,
boolean fullMatch)
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'tpublic 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.
public static java.lang.String[] tokenizeToStringArray(java.lang.String str,
java.lang.String delimiters)
The given delimiters string is supposed to consist of any number of
delimiter characters. Each of those characters can be used to separate
tokens. A delimiter is always a single character; for multi-character
delimiters, consider using delimitedListToStringArray
str - the String to tokenizedelimiters - the delimiter characters, assembled as String
(each of those characters is individually considered as delimiter).StringTokenizer,
String.trim()public static java.lang.String[] tokenizeToStringArray(java.lang.String str,
java.lang.String delimiters,
boolean trimTokens,
boolean ignoreEmptyTokens)
The given delimiters string is supposed to consist of any number of
delimiter characters. Each of those characters can be used to separate
tokens. A delimiter is always a single character; for multi-character
delimiters, consider using delimitedListToStringArray
str - the String to tokenizedelimiters - the delimiter characters, assembled as String
(each of those characters is individually considered as delimiter)trimTokens - trim the tokens via String's trimignoreEmptyTokens - omit empty tokens from the result array
(only applies to tokens that are empty after trimming; StringTokenizer
will not consider subsequent delimiters as token in the first place).null if the input String
was null)StringTokenizer,
String.trim()public static java.lang.String[] toStringArray(java.util.Collection collection)
collection - the Collection to copynull if the passed-in
Collection was null)