public class AntPathMatcher extends Objectimplements PatternMatcher
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.jspcom/*.jsp - matches all .jsp files in the com directorycom/**/test.jsp - matches all test.jsp files underneath the com pathorg/apache/shiro/**/*.jsp - matches all .jsp files underneath the org/apache/shiro pathorg/**/servlet/bla.jsp - matches org/apache/shiro/servlet/bla.jsp but also org/apache/shiro/testing/servlet/bla.jsp and org/servlet/bla.jspN.B.: This class was borrowed (with much appreciation) from the Spring Framework with modifications. We didn't want to reinvent the wheel of great work they've done, but also didn't want to force every Shiro user to depend on Spring
As per the Apache 2.0 license, the original copyright notice and all author and copyright information have remained in tact.
| Modifier and Type | Field and Description |
|---|---|
static String |
DEFAULT_PATH_SEPARATOR
Default path separator: "/"
|
| Constructor and Description |
|---|
AntPathMatcher()
|
| Modifier and Type | Method and Description |
|---|---|
protected boolean |
doMatch(String
Actually match the given
path against the given
pattern.
|
String |
extractPathWithinPattern(String
Given a pattern and a full path, determine the pattern-mapped part.
|
boolean |
isPattern(String
|
boolean |
match(String
|
boolean |
matches(String
Returns
true if the given
source matches the specified
pattern,
false otherwise.
|
boolean |
matchStart(String
|
void |
setPathSeparator(String
Set the path separator to use for pattern parsing.
|
public static final StringDEFAULT_PATH_SEPARATOR
public void setPathSeparator(StringpathSeparator)
public boolean isPattern(Stringpath)
public boolean matches(Stringpattern, String source)
PatternMatcher
true if the given
source matches the specified
pattern,
false otherwise.
matches in interface
PatternMatcher
pattern - the pattern to match against
source - the source to match
true if the given
source matches the specified
pattern,
false otherwise.
protected boolean doMatch(Stringpattern, String path, boolean fullMatch)
path against the given
pattern.
pattern - the pattern to match against
path - the path String to test
fullMatch - 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't
public StringextractPathWithinPattern(String pattern, 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.