0

0

如何高效识别并拦截拼接式恶意域名 spam

碧海醫心

碧海醫心

发布时间:2026-01-01 23:07:01

|

963人浏览过

|

来源于php中文网

原创

如何高效识别并拦截拼接式恶意域名 spam

本文介绍一种通过预处理+精确匹配的方式,精准识别形如 `a#b#c#d#e#f.com` 或 `a b c d e f.com` 等混淆拼接的恶意域名,避免传统正则误杀,提升反垃圾过滤的准确率与鲁棒性。

在对抗持续进化的垃圾信息发送者时,单纯依赖复杂正则表达式(如基于字符顺序和分隔符的模糊匹配)往往导致高误报率——例如原始代码中使用 (?

更可靠的做法是:先归一化(sanitization),再精确判定。核心思路是剥离所有非字母数字字符,还原出“干净”的纯字母序列,再判断是否包含目标关键词(如 abcdef):

// 步骤1:移除所有非字母数字字符(保留 a-z, A-Z, 0-9)
$cleaned = preg_replace('/[^A-Za-z0-9]/', '', $textfield);

// 步骤2:检查清洗后字符串是否包含目标域名主体(不区分大小写)
if (stripos($cleaned, 'abcdef') !== false) {
    // 触发拦截逻辑,例如标记为垃圾、拒绝提交或加入黑名单
    throw new Exception('Suspicious obfuscated domain detected.');
}

优势说明

家作
家作

淘宝推出的家装家居AI创意设计工具

下载
  • 高精度:仅当 a, b, c, d, e, f 按序连续出现(中间无干扰字符)时才触发,完全规避乱序匹配问题;
  • 强鲁棒性:自动兼容 a.b.c.d.e.f.com、a-b-c-d-e-f.com、a【b】c【d】e【f】.com 等数十种变体;
  • 低开销:两次轻量级字符串操作,远优于多层嵌套正则回溯,性能稳定;
  • 可扩展:支持批量检测,只需维护一个关键词数组:
    $spamKeywords = ['abcdef', 'xyzspam', 'phishlink'];
    foreach ($spamKeywords as $kw) {
        if (stripos($cleaned, $kw) !== false) {
            return true; // 恶意命中
        }
    }

⚠️ 注意事项

  • 若需防止 abcdefg(超长匹配)被误判,可改用单词边界匹配:preg_match('/\b' . preg_quote('abcdef', '/') . '\b/i', $cleaned),但通常域名主体本身无空格,直接 stripos 更高效;
  • 建议结合其他维度(如高频提交 IP、相似文本聚类、DNS 可解析性校验)构建多层防御,避免单点绕过;
  • 对用户可见内容(如评论、表单),清洗后应保留原始文本用于审计,仅将 $cleaned 用于检测逻辑。

该方法已在多个社区平台反 spam 实践中验证有效,兼顾准确性、可维护性与执行效率,是应对“字符混淆型”域名攻击的推荐方案。

相关专题

更多
c#是什么意思
c#是什么意思

C#是一种通用的面向对象编程语言,它在.NET框架上运行,可用于开发各种类型的应用程序。本专题为大家提供c#相关的各种文章、以及下载和课程。

257

2023.08.08

什么是c#
什么是c#

C#(读作C Sharp)是一种现代的、通用的、面向对象的编程语言。它由微软公司开发,于2000年首次发布,主要用于开发Windows桌面应用程序、Web应用程序、移动应用程序以及游戏开发等领域。C#是一种类型安全和托管的编程语言,它结合了C++的强大性能和C语言的简单易学特点,并引入了许多新的特性和概念,如委托、属性、泛型和异步编程等,以提高开发效率和代码可维护性。

177

2023.08.31

C#中base关键字的用法
C#中base关键字的用法

在C#中,base关键字用于访问当前类的基类成员,这包括基类的字段、属性、方法、构造函数、索引器以及事件。想了解更多C#的相关内容,可以阅读本专题下面的文章。

291

2024.03.13

C#Task用法
C#Task用法

Task在C#中是用于表示异步操作的对象,它位于System.Threading.Tasks命名空间中。想了解更多C#中各种用法的相关内容,可以阅读本专题下面的文章。

346

2024.03.14

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

508

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

247

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

724

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

209

2023.08.11

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
AngularJS教程
AngularJS教程

共24课时 | 2.2万人学习

【李炎恢】ThinkPHP8.x 后端框架课程
【李炎恢】ThinkPHP8.x 后端框架课程

共50课时 | 4.3万人学习

Swoft2.x速学之http api篇课程
Swoft2.x速学之http api篇课程

共16课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号