




本文详解如何使用正则表达式在 json 字符串中安全、准确地掩码邮箱字段值,解决因上下文限制导致的普通邮箱正则失效问题,并提供可直接运行的 java 示例与关键注意事项。
在处理敏感数据时,对 JSON 格式的 API 响应或日志进行邮箱掩码(如 test@example.com → t***@example.com)是常见需求。但直接复用单邮件字符串的正则(如 (?JSON 的引号结构和嵌套内容破坏了原始正则的上下文假设,尤其是 (?固定长度或有限长度的 (?
因此,必须重构正则逻辑,使其能:
✅ 推荐正则表达式(Java 兼容版):
"(?<=email\":\"[^\\s\"]{1,100})[a-zA-Z0-9](?=[^\\s\"@]*@)"? 表达式解析:
? 完整 Java 示例(可直接运行):
public class EmailMasker {
public static void main(String[] args) {
String jsonString = "{ \"name\":\"jhon\", \"email\":\"test.ing%[email protected]\" }";
// ✅ 关键:使用有限后瞻 + 安全前瞻的掩码正则

String masked = jsonString.replaceAll(
"(?<=email\":\"[^\\s\"]{1,100})[a-zA-Z0-9](?=[^\\s\"@]*@)",
"*"
);
System.out.println(masked);
// 输出:{ "name":"jhon", "email":"t***.***%**@gmail.com" }
}
}⚠️ 重要注意事项:
总结:在 JSON 中掩码邮箱,核心是用有限后瞻定位字段边界,用前瞻锚定邮箱结构。该正则兼顾准确性、安全性与 Java 兼容性,是生产环境轻量级脱敏的实用方案。