SpringBoot自定义处理器实现数据脱敏

  • 定义一个实体类
java 复制代码
@Data
public class UserModel {

    private Integer id;

    private String userName;

    private String idCard;

}
  • 定义一个控制器
javascript 复制代码
@RestController
public class TestController {

    @GetMapping("getUser")
    public UserModel getUser(){
        UserModel userModel = new UserModel();
        userModel.setId(1);
        userModel.setUserName("林青霞");
        userModel.setIdCard("3856597623");
        return userModel;
    }

}

控制器返回一个User对象,但是想对User对象的idCard属性值做脱敏处理,字符串后四位用*代替。

这里可以考虑使用Jackson自定义的序列化器实现,就类似于@DateFormat注解的实现效果。

  • 自定义一个属性序列化器
java 复制代码
public class IdCardDesensitizeHandler extends JsonSerializer  {

    @Override
    public String doDesensitize(String value) {
        if (value != null && value.length() > 4){
            //后四位替换为*
            value = value.substring(0,value.length() - 4) + "****";
        }
        return value;
    }

    @Override
    public void serialize(Object o, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException {
        if (o instanceof String){
            String value = (String) o;
            jsonGenerator.writeString(doDesensitize(value));
        }
    }
}

自定义序列化器,继承JsonSerializer,重写serialize方法

  • 标识对象属性自定义的序列化器,在idCard属性上标注 @JsonSerialize(using = IdCardDesensitizeHandler.class)
java 复制代码
@Data
public class UserModel {

    private Integer id;

    private String userName;

    @JsonSerialize(using = IdCardDesensitizeHandler.class)
    private String idCard;

}

SpringMVC在将对象转Json时用到了Jackson类库的ObjectMapper对象实现的,Jackson提供了自定义对象属性序列化器功能,当需要序列化idCard字段时,会自动调用注解指定的IdCardDesensitizeHandler序列化器完成实现。

一般在开发框架时都会提供各种场景的功能扩展点,例如SpringMVC自定义注解实现参数封装、自定义参数校验器,拦截器,Mybatis的statementhandler等,灵活使用这些扩展机制可以实现更强大的功能。

相关推荐
大梦百万秋3 分钟前
Spring Boot 实战:构建一个完整的电商平台
java·spring boot·后端
小泽呀x11 分钟前
springboot+javafx使用aop切面导致的fx:id不能被注入问题
java·spring boot·后端
每天写点bug22 分钟前
【go每日一题】 channel实现mutex锁
开发语言·后端·golang
customer0828 分钟前
【开源免费】基于SpringBoot+Vue.JS课程智能组卷系统(JAVA毕业设计)
java·vue.js·spring boot·后端·spring cloud·java-ee·开源
老牛源码37 分钟前
Z240009基于Java+SpringBoot+Vue+MySQL实现的医院在线挂号系统(附源码 配置配置 全套文档)
java·vue.js·spring boot
AI人H哥会Java38 分钟前
【JAVA】Java项目实战—Java EE项目:企业资源规划(ERP)系统
java·spring boot·mysql·java-ee
苹果醋31 小时前
SpringBoot | SpringBoot原理分析
运维·vue.js·spring boot·nginx·课程设计
drsonxu1 小时前
(3)spring security - 认识PasswordEncoder
java·数据库·spring·spring security
全职计算机毕业设计1 小时前
青少年夏令营管理系统的设计与开发(社团)+开题报告(springboot+freemarker)
java·spring boot·后端
深情废杨杨1 小时前
后端-redis在springboot项目中的使用步骤
java·spring boot·redis