|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.util.AntPathMatcher
public class AntPathMatcher
PathMatcher implementation for Ant-style path patterns. Examples are provided below.
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.jsp
com/*.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
Nested Class Summary | |
---|---|
private static class |
AntPathMatcher.AntPatternComparator
|
Field Summary | |
---|---|
static java.lang.String |
DEFAULT_PATH_SEPARATOR
Default path separator: "/" |
private java.lang.String |
pathSeparator
|
private static java.util.regex.Pattern |
VARIABLE_PATTERN
|
Constructor Summary | |
---|---|
AntPathMatcher()
|
Method Summary | |
---|---|
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 AntPathMatcher.AntPatternComparator suitable for sorting patterns in order of explicitness. |
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 |
setPathSeparator(java.lang.String pathSeparator)
Set the path separator to use for pattern parsing. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
private static final java.util.regex.Pattern VARIABLE_PATTERN
public static final java.lang.String DEFAULT_PATH_SEPARATOR
private java.lang.String pathSeparator
Constructor Detail |
---|
public AntPathMatcher()
Method Detail |
---|
public void setPathSeparator(java.lang.String pathSeparator)
public boolean isPattern(java.lang.String path)
PathMatcher
path
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 PathMatcher
path
- the path String to check
true
if the given path
represents a patternpublic boolean match(java.lang.String pattern, java.lang.String path)
PathMatcher
path
against the given pattern
,
according to this PathMatcher's matching strategy.
match
in interface PathMatcher
pattern
- the pattern to match againstpath
- the path String to test
true
if the supplied path
matched,
false
if it didn'tpublic boolean matchStart(java.lang.String pattern, java.lang.String path)
PathMatcher
path
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 PathMatcher
pattern
- the pattern to match againstpath
- the path String to test
true
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
- pattern to match against. Must not be null
.str
- string which must be matched against the pattern. Must not be null
.
true
if the string matches against the pattern, or false
otherwise.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 PathMatcher
pattern
- the path patternpath
- the full path to introspect
path
(never null
)public java.util.Map<java.lang.String,java.lang.String> extractUriTemplateVariables(java.lang.String pattern, java.lang.String path)
PathMatcher
For example: For pattern "/hotels/{hotel}" and path "/hotels/1", this method will return a map containing "hotel"->"1".
extractUriTemplateVariables
in interface PathMatcher
pattern
- the path pattern, possibly containing URI templatespath
- the full path to extract template variables from
public 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 PathMatcher
pattern1
- the first patternpattern2
- the second pattern
java.lang.IllegalArgumentException
- when the two patterns cannot be combinedpublic java.util.Comparator<java.lang.String> getPatternComparator(java.lang.String path)
AntPathMatcher.AntPatternComparator
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 PathMatcher
path
- the full path to use for comparison
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |