The default implementation is AntPathMatcher, supporting the * Ant-style pattern syntax. The description is from java spring framework.
目前版本还没有release版本,请不要使用,等完成测试,发布release版本后再进行使用。
Table Ant Wildcard Characters
Wildcard | Description |
---|---|
? | 匹配任何单字符 |
* | 匹配0或者任意数量的字符 |
** | 匹配0或者更多的目录 |
Table Example Ant-Style Path Patterns
Path | Description |
---|---|
/app/*.x | 匹配(Matches)所有在app路径下的.x文件 |
/app/p?ttern | 匹配(Matches) /app/pattern 和 /app/pXttern,但是不包括/app/pttern |
/**/example | 匹配(Matches) /app/example, /app/foo/example, 和 /example |
/app/**/dir/file. | 匹配(Matches) /app/dir/file.jsp, /app/foo/dir/file.html,/app/foo/bar/dir/file.pdf, 和 /app/dir/file.java |
/**/*.jsp | 匹配(Matches)任何的.jsp 文件 |
使用demo
package main
import "fmt"
import . "github.com/vibrantbyte/go-antpath/antpath"
//matchers
var matcher PathMatcher
func init(){
matcher = New()
}
func main(){
fmt.Println(matcher.Match("test","test"))
fmt.Println(matcher.Match("test*aaa", "testblaaaa"))
fmt.Println(matcher.Match("t?st", "test"))
fmt.Println(matcher.Match("/{bla}.*", "/testing.html"))
}