Java日志手机号脱敏工具类

发布于:2024-12-06 ⋅ 阅读:(20) ⋅ 点赞:(0)

背景

在开发过程中,很容易将用户敏感信息,例如手机号码、身份证等,打印在日志平台。为了保护用户数据,又不影响日志的打印,需要将日志中的敏感信息进行脱敏。

效果

没看明白,强烈建议 pull项目,执行一下项目中SensitiveUtils#main方法。

特性

  1. 支持多层级【Json】/【对象】字段脱敏

  2. 支持一次多字段脱敏

  3. 支持除【连续数组层次(下面会举例)】脱敏

  4. 不侵入业务代码(例如使用注解进行脱敏)

使用

1、输入为字符串/对象及单Json路径

// 传入对象
User user = new User();
user.setName("xiaoming");
user.setPhone("13455556666");
String strResult4 = SensitiveUtils.desMobilePhone(user, "phone");
System.out.println(strResult4); // {"phone":"134****6666","name":"xiaoming"}

// 传入json字符串
String str1 = "{\"name\":\"xiaoming\",\"phone\":\"13455556666\"}";
String strResult5 = SensitiveUtils.desMobilePhone(str1, "phone");
System.out.println(strResult5); // {"phone":"134****6666","name":"xiaoming"}

2、输入为字符串/对象及多Json路径

上图中,如果要脱敏全部手机号,路径则为 :phone , parent#phone

String str8 = "[{\"name\":\"xiaoliu\",\"phone\":\"13522222222\",\"parent\":[{\"name\":\"oldliu\",\"phone\":\"13533333333\"}]},{\"name\":\"xiaowang\",\"phone\":\"13500000000\",\"parent\":[{\"name\":\"oldwang\",\"phone\":\"13511111111\"},{\"name\":\"oldzhang\",\"phone\":\"13555555555\"}]}]";
String strResult8 = SensitiveUtils.desMobilePhone(str8, new HashSet<>(Arrays.asList("phone", "parent#phone")));
System.out.println(strResult8); // [{"parent":[{"phone":"135****3333","name":"oldliu"}],"phone":"135****2222","name":"xiaoliu"},{"parent":[{"phone":"135****1111","name":"oldwang"},{"phone":"135****5555","name":"oldzhang"}],"phone":"135****0000","name":"xiaowang"}]

上图中,如果要脱敏全部手机号,路径则为 :phone , parent#phone

已知缺陷

1、暂不支持连续俩层数组结构的JSON字符串/对象

2、暂不支持对String以外类型脱敏

3、暂不支持字符串中【对象JSON字符串】脱敏

{
    "info": "{\"data\":\"{\\\"phone\\\":\\\"13444444444\\\"}\"}"
}

未来优化方向

  1. 增加更多脱敏类型(如身份证号码)

  2. 支持一个对象/Json字符串多种脱敏类型,例如:一个字符串同时脱敏手机号、身份证号

  3. 连续数组脱敏(待定)

  4. 支持非String类型字段脱敏(待定)

  5. 字符串中【对象JSON字符串】脱敏(待定)

文章转载自:帅气的涛啊

原文链接:https://www.cnblogs.com/handsometaoa/p/18578888

体验地址:引迈 - JNPF快速开发平台_低代码开发平台_零代码开发平台_流程设计器_表单引擎_工作流引擎_软件架构


网站公告

今日签到

点亮在社区的每一天
去签到