0

0

如何有效拦截拼接式恶意域名的垃圾信息

心靈之曲

心靈之曲

发布时间:2026-01-01 23:31:02

|

955人浏览过

|

来源于php中文网

原创

如何有效拦截拼接式恶意域名的垃圾信息

本文介绍一种通过预处理文本并结合字符串匹配来精准识别拼接式 spam 域名(如 a#b#c#d#e#f.com)的实用方案,避免正则误杀,提升过滤准确率。

在对抗持续绕过规则的垃圾信息发送者时,依赖复杂正则表达式(如 (?先归一化,再精确判断。

核心策略分两步:

  1. 文本净化(Sanitization):移除所有非字母数字字符,仅保留 a–z、A–Z、0–9,将各类干扰格式统一还原为原始字符序列;
  2. 子串匹配(Exact Substring Check):在净化后的纯文本中,直接查找目标关键词(如 'abcdef'),无需关心原始分隔符。

示例代码如下:

// 假设 $textfield 是用户提交的待检测文本(可能含 URL、描述等)
$cleaned = preg_replace('/[^A-Za-z0-9]/', '', $textfield); // 一步清除所有符号/空格/特殊分隔符

// 检查是否包含被滥用的连续域名片段(不区分大小写)
if (stripos($cleaned, 'abcdef') !== false) {
    // 触发拦截逻辑:标记为 spam,拒绝发布或要求人工审核
    die('Spam domain detected: abcdef.com variant blocked.');
}

优势说明

家作
家作

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

下载
  • ✅ 简洁高效:无回溯风险,性能远优于多组前瞻断言的正则;
  • ✅ 高精度:仅当 a, b, c, d, e, f 按序连续出现(中间无其他字母数字干扰)时才触发,彻底规避“任意顺序匹配”的误报;
  • ✅ 易扩展:如新增 xyz123.com 变体,只需增加一行 stripos($cleaned, 'xyz123') 即可;
  • ✅ 兼容性强:对 a b c d e f.com、a$b$c$d$e$f.com、a·b·c·d·e·f.com、甚至 azuojiankuohaophpcnbyoujiankuohaophpcnc[d]e{f}.com 均能正确归一化为 abcdefcom,从而捕获 abcdef 子串。

⚠️ 注意事项

  • 若目标域名本身含数字或大小写混合(如 AbC123.com),请确保 stripos() 或统一转小写后再匹配(strtolower($cleaned));
  • 此法假设 spammer 的核心特征是字符顺序不变但插入干扰符;若其开始打乱顺序(如 f#e#d#c#b#a.com),需升级为字符频次统计或编辑距离算法,但当前场景下极少发生;
  • 建议配合日志记录被拦截的原始 $textfield,用于持续分析新变种,动态更新关键词列表。

综上,与其在正则迷宫中疲于奔命,不如用“清洗 + 精确匹配”构建一道轻量而锋利的防线——简单,可靠,且经得起时间考验。

相关专题

更多
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号