有什么办法能快速匹配某一域名是否在白名单中?

2019-06-06 16:06:00 +08:00
 john990
白名单是个正则表达式列表(大概有 2000 个):
例如:
(^|\.)abc\.baidu\.com$
(^|\.)123\.baidu\.com$
...

然后浏览器发起了个请求:666.baidu.com ,怎么能快速计算出白名单是否包含这个域名?
有什么比较好的算法吗?
1986 次点击
所在节点    问与答
5 条回复
azh7138m
2019-06-06 16:26:15 +08:00
域名一级的匹配的话,就是不存在 prefix([^.]+).domain 的格式的话,用前缀树会不会快点,一次匹配一级域名。

我的 uBlock Origin 有 16+w 过滤规则,感觉也不慢,真的量大可以参考下他的算法?
Trie 比正则性能是翻倍了 https://raw.githack.com/gorhill/uBlock/master/docs/tests/hnset-benchmark.html
senghoo
2019-06-06 16:33:59 +08:00
构建个 dfa
azh7138m
2019-06-06 16:55:28 +08:00
我的意思是每个节点放一级域名
com - baidu - wiki - true
|- tieba - false

任意级啊,前缀树也没要求你固定级别
john990
2019-06-06 16:57:46 +08:00
@azh7138m 对!这个办法好,谢谢~
john990
2019-06-06 16:59:44 +08:00

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/571548

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX