如何在 JSON 字符串中精准掩码邮箱地址(基于正则表达式的可靠实现)

发布时间 - 2026-01-30 00:00:00    点击率:

本文介绍一种安全、可移植的正则表达式方案,用于在 json 字符串中精准定位并掩码邮箱字段的局部字符(如 `t***.***%**@gmail.com`),避免误匹配 html 标签或相邻字段,兼容 java 等主流语言。

在处理敏感数据(如用户邮箱)时,直接对原始 JSON 字符串进行脱敏是常见需求。但若沿用纯邮箱字符串的掩码正则(如 (?)或转义字符干扰。

✅ 正确思路:结合 JSON 字段边界 + 邮箱值内容约束,而非泛匹配。推荐使用以下增强型正则:

String jsonString = "{ \"name\":\"jhon\", \"email\":\"test.ing%[email protected]\" }";
String maskedJson = jsonString.replaceAll("(?<=email\":\"[^\\s\"]{1,100})[a-zA-Z0-9](?=[^\\s\"@]*@)", "*");
System.out.println(maskedJson);
// 输出:{ "name":"jhon", "email":"t***.***%**@gmail.com" }

? 正则解析(关键设计点):

  • (?有限长度正向后查找
    确保目标字符前紧邻 "email":",且其后最多 100 个非空白、非双引号字符(即限制在当前 JSON 字符串值范围内,避免跨字段匹配)。{1,100} 可根据实际邮箱最大长度调整(如 {1,200} 更稳妥)。
  • [a-zA-Z0-9]:精确匹配需掩码的单个字母或数字(跳过 .、%、@ 等分隔符)。
  • (?=[^\\s\"@]*@):正向先行断言
    要求该字符右侧直到 @ 符号之间,只允许出现非空白、非双引号、非 @ 的字符——确保匹配发

    生在邮箱本地部分(local-part),而非域名或引号外。

⚠️ 注意事项:

  • 不依赖贪婪匹配或无限回溯:[^\\s\"]+ 和 [^\\s\"@]* 显式排除 JSON 结构符号,杜绝因 .* 导致的越界匹配(如误吞下一个字段的键名)。
  • Java 字符串需双重转义:" 写为 \",\ 写为 \\,故 [^\\s\"] 对应正则中的 [^\\s"]。
  • 不修改 HTML 标签或 data-cfemail 属性:该正则仅作用于 JSON 值中可见的邮箱文本(即 test.ing%...@gmail.com),对 标签内的 data-cfemail 等属性完全无影响,符合安全脱敏原则。
  • 慎用于嵌套/多层 JSON:本方案适用于扁平化 JSON(单层 email 字段)。若需处理嵌套对象(如 "user":{"contact":{"email":"..."}}),建议先解析为对象再操作,或升级为支持递归的 JSONPath + 自定义处理器。

? 总结:在 JSON 字符串中掩码邮箱,核心是「字段锚定 + 值域隔离 + 语义限定」。相比简单全局替换,该正则兼顾准确性、健壮性与可维护性,是生产环境推荐的轻量级脱敏实践。


# java  # html  # js  # json  # 正则表达式  # 处理器  # ai  # cdn  # 邮箱  # 敏感数据  # 字符串  # 递归  # class  # 对象  # 掩码  # 而非  # 值域  # 双引号  # 最多  # 推荐使用  # 适用于  # 自定义  # 升级为 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel storage目录权限问题_Laravel文件写入权限设置  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  如何在万网自助建站平台快速创建网站?  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  怎么用AI帮你为初创公司进行市场定位分析?  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何在阿里云通过域名搭建网站?  什么是javascript作用域_全局和局部作用域有什么区别?  七夕网站制作视频,七夕大促活动怎么报名?  开心动漫网站制作软件下载,十分开心动画为何停播?  php结合redis实现高并发下的抢购、秒杀功能的实例  如何快速搭建高效服务器建站系统?  Bootstrap整体框架之CSS12栅格系统  浅谈redis在项目中的应用  Laravel Session怎么存储_Laravel Session驱动配置详解  Angular 表单中正确绑定输入值以确保提交与验证正常工作  简历没回改:利用AI润色让你的文字更专业  网站制作软件有哪些,制图软件有哪些?  C#如何调用原生C++ COM对象详解  php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】  mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?  google浏览器怎么清理缓存_谷歌浏览器清除缓存加速详细步骤  Laravel如何使用查询构建器?(Query Builder高级用法)  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  高防服务器:AI智能防御DDoS攻击与数据安全保障  java获取注册ip实例  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  Android Socket接口实现即时通讯实例代码  消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工  免费网站制作appp,免费制作app哪个平台好?  php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】  Python文件操作最佳实践_稳定性说明【指导】  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  Swift开发中switch语句值绑定模式  为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议  ,怎么在广州志愿者网站注册?  WEB开发之注册页面验证码倒计时代码的实现  Internet Explorer官网直接进入 IE浏览器在线体验版网址  潮流网站制作头像软件下载,适合母子的网名有哪些?  Android利用动画实现背景逐渐变暗  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  香港服务器建站指南:免备案优势与SEO优化技巧全解析  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何快速搭建二级域名独立网站?  Swift中switch语句区间和元组模式匹配