类 AntPathMatcher
- java.lang.Object
-
- com.alibaba.nacos.common.packagescan.resource.AntPathMatcher
-
- 所有已实现的接口:
PathMatcher
public class AntPathMatcher extends java.lang.Object implements PathMatcher
Copy from https://github.com/spring-projects/spring-framework.git, with less modificationsPathMatcherimplementation 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— matchescom/test.jspbut alsocom/tast.jsporcom/txst.jspcom/*.jsp— matches all.jspfiles in thecomdirectorycom/**/test.jsp— matches alltest.jspfiles underneath thecompathorg/springframework/**/*.jsp— matches all.jspfiles underneath theorg/springframeworkpathorg/**/servlet/bla.jsp— matchesorg/springframework/servlet/bla.jspbut alsoorg/springframework/testing/servlet/bla.jspandorg/servlet/bla.jspcom/{filename:\\w+}.jspwill matchcom/test.jspand assign the valuetestto thefilenamevariable
- 从以下版本开始:
- 16.07.2003
- 作者:
- Alef Arendsen, Juergen Hoeller, Rob Harrop, Arjen Poutsma, Rossen Stoyanchev, Sam Brannen, Vladislav Kisel
-
-
嵌套类概要
嵌套类 修饰符和类型 类 说明 protected static classAntPathMatcher.AntPathStringMatcherTests whether or not a string matches against a pattern via aPattern.protected static classAntPathMatcher.AntPatternComparatorThe defaultComparatorimplementation returned bygetPatternComparator(String).private static classAntPathMatcher.PathSeparatorPatternCacheA simple cache for patterns that depend on the configured path separator.
-
字段概要
字段 修饰符和类型 字段 说明 private static intCACHE_TURNOFF_THRESHOLDprivate java.lang.BooleancachePatternsprivate booleancaseSensitivestatic java.lang.StringDEFAULT_PATH_SEPARATORDefault path separator: "/".private java.lang.StringpathSeparatorprivate AntPathMatcher.PathSeparatorPatternCachepathSeparatorPatternCache(专用程序包) java.util.Map<java.lang.String,AntPathMatcher.AntPathStringMatcher>stringMatcherCacheprivate java.util.Map<java.lang.String,java.lang.String[]>tokenizedPatternCacheprivate booleantrimTokensprivate static java.util.regex.PatternVARIABLE_PATTERNprivate static char[]WILDCARD_CHARS
-
构造器概要
构造器 构造器 说明 AntPathMatcher()Create a new instance with theDEFAULT_PATH_SEPARATOR.AntPathMatcher(java.lang.String pathSeparator)A convenient, alternative constructor to use with a custom path separator.
-
方法概要
所有方法 实例方法 具体方法 修饰符和类型 方法 说明 java.lang.Stringcombine(java.lang.String pattern1, java.lang.String pattern2)Combine two patterns into a new pattern.private java.lang.Stringconcat(java.lang.String path1, java.lang.String path2)private voiddeactivatePatternCache()protected booleandoMatch(java.lang.String pattern, java.lang.String path, boolean fullMatch, java.util.Map<java.lang.String,java.lang.String> uriTemplateVariables)Actually match the givenpathagainst the givenpattern.java.lang.StringextractPathWithinPattern(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 aComparatorsuitable for sorting patterns in order of explicitness.protected AntPathMatcher.AntPathStringMatchergetStringMatcher(java.lang.String pattern)Build or retrieve anAntPathMatcher.AntPathStringMatcherfor the given pattern.booleanisPattern(java.lang.String path)Does the givenpathrepresent a pattern that can be matched by an implementation of this interface?private booleanisPotentialMatch(java.lang.String path, java.lang.String[] pattDirs)private booleanisWildcardChar(char c)booleanmatch(java.lang.String pattern, java.lang.String path)Match the givenpathagainst the givenpattern, according to this PathMatcher's matching strategy.booleanmatchStart(java.lang.String pattern, java.lang.String path)Match the givenpathagainst the corresponding part of the givenpattern, according to this PathMatcher's matching strategy.private booleanmatchStrings(java.lang.String pattern, java.lang.String str, java.util.Map<java.lang.String,java.lang.String> uriTemplateVariables)Test whether or not a string matches against a pattern.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(java.lang.String pathSeparator)Set the path separator to use for pattern parsing.voidsetTrimTokens(boolean trimTokens)Specify whether to trim tokenized paths and patterns.private intskipSegment(java.lang.String path, int pos, java.lang.String prefix)private intskipSeparator(java.lang.String path, int pos, java.lang.String separator)protected java.lang.String[]tokenizePath(java.lang.String path)Tokenize the given path into parts, based on this matcher's settings.protected java.lang.String[]tokenizePattern(java.lang.String pattern)Tokenize the given path pattern into parts, based on this matcher's settings.
-
-
-
字段详细资料
-
DEFAULT_PATH_SEPARATOR
public static final java.lang.String DEFAULT_PATH_SEPARATOR
Default path separator: "/".- 另请参阅:
- 常量字段值
-
CACHE_TURNOFF_THRESHOLD
private static final int CACHE_TURNOFF_THRESHOLD
- 另请参阅:
- 常量字段值
-
VARIABLE_PATTERN
private static final java.util.regex.Pattern VARIABLE_PATTERN
-
WILDCARD_CHARS
private static final char[] WILDCARD_CHARS
-
pathSeparator
private java.lang.String pathSeparator
-
pathSeparatorPatternCache
private AntPathMatcher.PathSeparatorPatternCache pathSeparatorPatternCache
-
caseSensitive
private boolean caseSensitive
-
trimTokens
private boolean trimTokens
-
cachePatterns
private volatile java.lang.Boolean cachePatterns
-
tokenizedPatternCache
private final java.util.Map<java.lang.String,java.lang.String[]> tokenizedPatternCache
-
stringMatcherCache
final java.util.Map<java.lang.String,AntPathMatcher.AntPathStringMatcher> stringMatcherCache
-
-
构造器详细资料
-
AntPathMatcher
public AntPathMatcher()
Create a new instance with theDEFAULT_PATH_SEPARATOR.
-
AntPathMatcher
public AntPathMatcher(java.lang.String pathSeparator)
A convenient, alternative constructor to use with a custom path separator.- 参数:
pathSeparator- the path separator to use, must not benull.- 从以下版本开始:
- 4.1
-
-
方法详细资料
-
setPathSeparator
public void setPathSeparator(java.lang.String pathSeparator)
Set the path separator to use for pattern parsing. Default is "/", as in Ant.
-
setCaseSensitive
public void setCaseSensitive(boolean caseSensitive)
Specify whether to perform pattern matching in a case-sensitive fashion. Default istrue. Switch this tofalsefor case-insensitive matching.- 从以下版本开始:
- 4.2
-
setTrimTokens
public void setTrimTokens(boolean trimTokens)
Specify whether to trim tokenized paths and patterns. Default isfalse.
-
setCachePatterns
public 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.- 从以下版本开始:
- 4.0.1
- 另请参阅:
getStringMatcher(String)
-
deactivatePatternCache
private void deactivatePatternCache()
-
isPattern
public boolean isPattern(java.lang.String path)
从接口复制的说明: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.- 指定者:
isPattern在接口中PathMatcher- 参数:
path- the path to check- 返回:
trueif the givenpathrepresents a pattern
-
match
public boolean match(java.lang.String pattern, java.lang.String path)从接口复制的说明:PathMatcherMatch the givenpathagainst the givenpattern, according to this PathMatcher's matching strategy.- 指定者:
match在接口中PathMatcher- 参数:
pattern- the pattern to match againstpath- the path to test- 返回:
trueif the suppliedpathmatched,falseif it didn't
-
matchStart
public boolean matchStart(java.lang.String pattern, java.lang.String path)从接口复制的说明: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.
- 指定者:
matchStart在接口中PathMatcher- 参数:
pattern- the pattern to match againstpath- the path to test- 返回:
trueif the suppliedpathmatched,falseif it didn't
-
doMatch
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 givenpathagainst the givenpattern.- 参数:
pattern- the pattern to match againstpath- the path to testfullMatch- whether a full pattern match is required (else a pattern match as far as the given base path goes is sufficient)- 返回:
trueif the suppliedpathmatched,falseif it didn't
-
isPotentialMatch
private boolean isPotentialMatch(java.lang.String path, java.lang.String[] pattDirs)
-
skipSegment
private int skipSegment(java.lang.String path, int pos, java.lang.String prefix)
-
skipSeparator
private int skipSeparator(java.lang.String path, int pos, java.lang.String separator)
-
isWildcardChar
private boolean isWildcardChar(char c)
-
tokenizePattern
protected java.lang.String[] tokenizePattern(java.lang.String pattern)
Tokenize the given path pattern into parts, based on this matcher's settings. Performs caching based onsetCachePatterns(boolean), delegating totokenizePath(String)for the actual tokenization algorithm.- 参数:
pattern- the pattern to tokenize- 返回:
- the tokenized pattern parts
-
tokenizePath
protected java.lang.String[] tokenizePath(java.lang.String path)
Tokenize the given path into parts, based on this matcher's settings.- 参数:
path- the path to tokenize- 返回:
- the tokenized path parts
-
matchStrings
private boolean matchStrings(java.lang.String pattern, java.lang.String str, java.util.Map<java.lang.String,java.lang.String> uriTemplateVariables)Test whether or not a string matches against a pattern.- 参数:
pattern- the pattern to match against (nevernull)str- the String which must be matched against the pattern (nevernull)- 返回:
trueif the string matches against the pattern, orfalseotherwise
-
getStringMatcher
protected AntPathMatcher.AntPathStringMatcher getStringMatcher(java.lang.String pattern)
Build or retrieve anAntPathMatcher.AntPathStringMatcherfor the given pattern. The default implementation checks this AntPathMatcher's internal cache (seesetCachePatterns(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.- 参数:
pattern- the pattern to match against (nevernull)- 返回:
- a corresponding AntPathStringMatcher (never
null) - 另请参阅:
setCachePatterns(boolean)
-
extractPathWithinPattern
public java.lang.String extractPathWithinPattern(java.lang.String pattern, java.lang.String path)Given 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'
match(java.lang.String, java.lang.String)returnstruefor 'pattern' and 'path', but does not enforce this.- 指定者:
extractPathWithinPattern在接口中PathMatcher- 参数:
pattern- the path patternpath- the full path to introspect- 返回:
- the pattern-mapped part of the given
path(nevernull)
- '
-
extractUriTemplateVariables
public java.util.Map<java.lang.String,java.lang.String> extractUriTemplateVariables(java.lang.String pattern, java.lang.String path)从接口复制的说明: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".
- 指定者:
extractUriTemplateVariables在接口中PathMatcher- 参数:
pattern- the path pattern, possibly containing URI templatespath- the full path to extract template variables from- 返回:
- a map, containing variable names as keys; variables values as values
-
combine
public java.lang.String combine(java.lang.String pattern1, java.lang.String pattern2)Combine 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.Examples
Pattern 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- 指定者:
combine在接口中PathMatcher- 参数:
pattern1- the first patternpattern2- the second pattern- 返回:
- the combination of the two patterns
- 抛出:
java.lang.IllegalArgumentException- if the two patterns cannot be combined
-
concat
private java.lang.String concat(java.lang.String path1, java.lang.String path2)
-
getPatternComparator
public java.util.Comparator<java.lang.String> getPatternComparator(java.lang.String path)
Given a full path, returns aComparatorsuitable for sorting patterns in order of explicitness. ThisComparatorwill 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/*
/hotels/2, the pattern/hotels/2will be sorted before/hotels/1.- 指定者:
getPatternComparator在接口中PathMatcher- 参数:
path- the full path to use for comparison- 返回:
- a comparator capable of sorting patterns in order of explicitness
-
-