AdGuard浏览器扩展中$popup与third-party修饰符组合导致文档拦截问题分析
2025-06-24 08:30:33作者:裴锟轩Denise
问题概述
在AdGuard浏览器扩展的使用过程中,发现当同时使用$popup和$third-party这两个修饰符时,会导致目标网站被意外拦截。具体表现为:单独使用这两个修饰符时网站可以正常访问,但当它们组合使用时($popup,third-party),目标网站会被错误地完全拦截。
技术背景
AdGuard的过滤规则系统允许通过修饰符对规则进行精细化控制。其中:
$popup修饰符用于阻止弹出窗口$third-party修饰符用于匹配第三方资源
这两个修饰符本应协同工作,但在特定情况下它们的组合会产生意外的拦截行为。
问题复现步骤
- 禁用所有预置过滤器
- 在用户自定义规则中添加
||livejasmin.com^$popup,third-party - 访问目标网站时发现整个页面被拦截
而如果分别使用:
||livejasmin.com^$third-party
||livejasmin.com^$popup
网站则可以正常加载。
技术分析
这个问题可能源于修饰符组合处理逻辑中的缺陷。当两个修饰符组合使用时,过滤引擎可能错误地将主文档也纳入了拦截范围,而实际上:
$third-party修饰符本应只影响跨域请求$popup修饰符本应只针对弹出窗口- 主文档既不是第三方资源,也不是弹出窗口,不应被拦截
解决方案
开发团队已确认并修复了此问题。修复后的版本将正确处理修饰符组合,确保:
- 主文档不会被错误拦截
- 弹出窗口和第三方资源的拦截功能保持正常
- 修饰符组合使用时各功能互不干扰
用户建议
遇到类似问题时,用户可以:
- 暂时拆解组合修饰符为单独规则
- 检查AdGuard扩展是否为最新版本
- 关注官方更新日志获取修复信息
这个问题展示了浏览器扩展过滤规则处理中的复杂性,也体现了AdGuard团队对产品稳定性的持续改进。
登录后查看全文
热门项目推荐
相关项目推荐
暂无数据
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
540
3.77 K
Ascend Extension for PyTorch
Python
351
415
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
612
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
338
185
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
987
253
openGauss kernel ~ openGauss is an open source relational database management system
C++
169
233
暂无简介
Dart
778
193
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.35 K
758
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
115
141