mirror of
https://github.com/TeaOSLab/EdgeNode.git
synced 2025-11-03 23:20:25 +08:00
优化正则表达式/修复一些测试用例
This commit is contained in:
@@ -7,7 +7,7 @@ import (
|
||||
"strings"
|
||||
)
|
||||
|
||||
var prefixReg = regexp.MustCompile(`^\(\?(\w+)\)`) // (?x)
|
||||
var prefixReg = regexp.MustCompile(`^\(\?([\w\s]+)\)`) // (?x)
|
||||
var prefixReg2 = regexp.MustCompile(`^\(\?([\w\s]*:)`) // (?x: ...
|
||||
var braceZero = regexp.MustCompile(`^{\s*0*\s*}`) // {0}
|
||||
var braceZero2 = regexp.MustCompile(`^{\s*0*\s*,`) // {0, x}
|
||||
@@ -18,6 +18,7 @@ type Regexp struct {
|
||||
|
||||
isStrict bool
|
||||
isCaseInsensitive bool
|
||||
keywords []string
|
||||
keywordsMap RuneMap
|
||||
}
|
||||
|
||||
@@ -67,11 +68,24 @@ func (this *Regexp) init() {
|
||||
}
|
||||
|
||||
var keywords = this.ParseKeywords(exp)
|
||||
this.keywords = keywords
|
||||
if len(keywords) > 0 {
|
||||
this.keywordsMap = NewRuneTree(keywords)
|
||||
}
|
||||
}
|
||||
|
||||
func (this *Regexp) Keywords() []string {
|
||||
return this.keywords
|
||||
}
|
||||
|
||||
func (this *Regexp) Raw() *regexp.Regexp {
|
||||
return this.rawRegexp
|
||||
}
|
||||
|
||||
func (this *Regexp) IsCaseInsensitive() bool {
|
||||
return this.isCaseInsensitive
|
||||
}
|
||||
|
||||
func (this *Regexp) MatchString(s string) bool {
|
||||
if this.keywordsMap != nil {
|
||||
var b = this.keywordsMap.Lookup(s, this.isCaseInsensitive)
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package utils
|
||||
|
||||
import (
|
||||
"github.com/TeaOSLab/EdgeNode/internal/re"
|
||||
"net/http"
|
||||
"regexp"
|
||||
"runtime"
|
||||
@@ -11,14 +12,14 @@ import (
|
||||
)
|
||||
|
||||
func TestMatchStringCache(t *testing.T) {
|
||||
regex := regexp.MustCompile(`\d+`)
|
||||
regex := re.MustCompile(`\d+`)
|
||||
t.Log(MatchStringCache(regex, "123"))
|
||||
t.Log(MatchStringCache(regex, "123"))
|
||||
t.Log(MatchStringCache(regex, "123"))
|
||||
}
|
||||
|
||||
func TestMatchBytesCache(t *testing.T) {
|
||||
regex := regexp.MustCompile(`\d+`)
|
||||
regex := re.MustCompile(`\d+`)
|
||||
t.Log(MatchBytesCache(regex, []byte("123")))
|
||||
t.Log(MatchBytesCache(regex, []byte("123")))
|
||||
t.Log(MatchBytesCache(regex, []byte("123")))
|
||||
@@ -52,7 +53,7 @@ func BenchmarkMatchStringCache(b *testing.B) {
|
||||
runtime.GOMAXPROCS(1)
|
||||
|
||||
data := strings.Repeat("HELLO", 512)
|
||||
regex := regexp.MustCompile(`(?iU)\b(eval|system|exec|execute|passthru|shell_exec|phpinfo)\b`)
|
||||
regex := re.MustCompile(`(?iU)\b(eval|system|exec|execute|passthru|shell_exec|phpinfo)\b`)
|
||||
_ = MatchStringCache(regex, data)
|
||||
|
||||
for i := 0; i < b.N; i++ {
|
||||
@@ -63,9 +64,18 @@ func BenchmarkMatchStringCache(b *testing.B) {
|
||||
func BenchmarkMatchStringCache_WithoutCache(b *testing.B) {
|
||||
runtime.GOMAXPROCS(1)
|
||||
|
||||
data := strings.Repeat("HELLO", 512)
|
||||
regex := regexp.MustCompile(`(?iU)\b(eval|system|exec|execute|passthru|shell_exec|phpinfo)\b`)
|
||||
data := strings.Repeat("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36", 8)
|
||||
regex := re.MustCompile(`(?iU)\b(eval|system|exec|execute|passthru|shell_exec|phpinfo)\b`)
|
||||
for i := 0; i < b.N; i++ {
|
||||
_ = regex.MatchString(data)
|
||||
}
|
||||
}
|
||||
|
||||
func BenchmarkMatchStringCache_WithoutCache2(b *testing.B) {
|
||||
runtime.GOMAXPROCS(1)
|
||||
|
||||
data := strings.Repeat("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/96.0.4664.110 Safari/537.36", 8)
|
||||
regex := regexp.MustCompile(`(?iU)\b(eval|system|exec|execute|passthru|shell_exec|phpinfo)\b`)
|
||||
for i := 0; i < b.N; i++ {
|
||||
_ = regex.MatchString(data)
|
||||
}
|
||||
@@ -74,8 +84,8 @@ func BenchmarkMatchStringCache_WithoutCache(b *testing.B) {
|
||||
func BenchmarkMatchBytesCache_WithoutCache(b *testing.B) {
|
||||
runtime.GOMAXPROCS(1)
|
||||
|
||||
data := []byte(strings.Repeat("HELLO", 512))
|
||||
regex := regexp.MustCompile(`(?iU)\b(eval|system|exec|execute|passthru|shell_exec|phpinfo)\b`)
|
||||
data := []byte(strings.Repeat("HELLO", 128))
|
||||
regex := re.MustCompile(`(?iU)\b(eval|system|exec|execute|passthru|shell_exec|phpinfo)\b`)
|
||||
|
||||
for i := 0; i < b.N; i++ {
|
||||
_ = regex.Match(data)
|
||||
|
||||
Reference in New Issue
Block a user