当前位置: 首页 > article >正文

springboot jackson 数据脱敏

整体思路

  1. 对于一个class 包含多个字段,哪个字段是敏感字段,该字段是手机号 还是邮箱,希望如何进行脱敏,这些需要被定义,因此第一步定义《敏感注解》
  2. 将注解放到指定得class的字段上,并且标记是邮箱 还是 手机号
  3. 重写序列化逻辑,将明文手机号替换为密文

第一步:定义注解
其中
@Target(ElementType.FIELD) 表示要修饰的内容是字段
@JsonSerialize(using = SensitiveJsonSerializer.class) 表示具体的序列化方法要使用SensitiveJsonSerializer定义的,该SensitiveJsonSerializer后面会说到。
DesensitizedType desensitizedType(); 表示使用注解时,可以传递一个参数,该参数时一个方法

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
@JacksonAnnotationsInside
@JsonSerialize(using = SensitiveJsonSerializer.class)
public @interface Sensitive
{
    DesensitizedType desensitizedType();
}

DesensitizedType 定义如下

public enum DesensitizedType
{
    /**
     * 姓名,第2位星号替换
     */
    USERNAME(s -> s.replaceAll("(\\S)\\S(\\S*)", "$1*$2")),

    /**
     * 身份证,中间10位星号替换
     */
    ID_CARD(s -> s.replaceAll("(\\d{4})\\d{10}(\\d{4})", "$1** **** ****$2")),

    /**
     * 手机号,中间4位星号替换
     */
    PHONE(s -> s.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2")),

    /**
     * 电子邮箱,仅显示第一个字母和@后面的地址显示,其他星号替换
     */
    EMAIL(s -> s.replaceAll("(^.)[^@]*(@.*$)", "$1****$2")),

    /**
     * 银行卡号,保留最后4位,其他星号替换
     */
    BANK_CARD(s -> s.replaceAll("\\d{15}(\\d{3})", "**** **** **** **** $1"));


    private final Function<String, String> desensitizer;

    DesensitizedType(Function<String, String> desensitizer)
    {
        this.desensitizer = desensitizer;
    }

    public Function<String, String> desensitizer()
    {
        return desensitizer;
    }
}

第二步:修饰字段,指明该字段问密文字段 email

public class User {
    @Sensitive(desensitizedType = DesensitizedType.EMAIL)
    private String name;

    private Integer age;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }
}

第三步,重写序列化逻辑

    private DesensitizedType desensitizedType;

    @Override
    public void serialize(String s, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException {
        jsonGenerator.writeString(desensitizedType.desensitizer().apply(s));
    }

    @Override
    public JsonSerializer<?> createContextual(SerializerProvider prov, BeanProperty property) throws JsonMappingException {
        Sensitive annotation = property.getAnnotation(Sensitive.class);
        if (Objects.nonNull(annotation) && Objects.equals(String.class, property.getType().getRawClass()))
        {
            this.desensitizedType = annotation.desensitizedType();
            return this;
        }
        return prov.findValueSerializer(property.getType(), property);
    }

http://www.kler.cn/news/362061.html

相关文章:

  • Rust : FnOnce、线程池与多策略执行
  • ElasticSearch-7.17.10集群升级至ElasticSearch-7.17.24
  • Leetcode 最小路径和
  • VMamba:视觉SSM
  • 《重置MobaXterm密码并连接Linux虚拟机的完整操作指南》
  • html+css+js实现Notification 通知
  • json键值对组成的数组去重。
  • 13.3 Linux_网络编程_多路复用I/O接入多客户端
  • 【C语言】一维数组的定义与初始化
  • 设计模式:类与类之间关系的表示方式(聚合,组合,依赖,继承,实现)
  • 【编程语言】Kotlin快速入门 - 伴生对象与懒加载
  • 关于mysql jdbc驱动fetchSize属性的说明
  • 华山论剑之Rust的Trait
  • 【Linux】一个简单while循环实现【严格轮转】,从而理解什么是【多线程的忙等待】
  • 挑战性课程《信号处理系统》(原信号与系统+数字信号处理)课程课程设计
  • Mamba学习笔记(4)——Mamba核心
  • 代码工艺:写代码的好习惯
  • 使用python自制桌面宠物,好玩!——枫原万叶桌宠,可以直接打包成exe去跟朋友炫耀。。。
  • 【LeetCode】123.买卖股票的最佳时间
  • 使用 NLP 和模式匹配检测、评估和编辑日志中的个人身份信息 - 第 1 部分
  • VBA技术资料MF212:确定Excel文件是否正在使用中
  • SSM与Springboot是什么关系? -----区别与联系
  • Psychophysiology:脑-心交互如何影响个体的情绪体验?
  • java的继承
  • git提交信息写错处理方式
  • Lua脚本的原子性