基于Jackson实现数据脱敏

1.、编写序列化类

public class SensitiveSerializer extends JsonSerializer<String> implements ContextualSerializer {

    private SensitiveEnum sensitiveEnum;

    @Override
    public void serialize(String value, JsonGenerator gen, SerializerProvider serializers) throws IOException {
        gen.writeString(sensitiveEnum.desensitizer().apply(value));
    }

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

2、自定义注解,并指定序列化类为【SensitiveSerializer】

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
@JacksonAnnotationsInside
@JsonSerialize(using = SensitiveSerializer.class)
public @interface SensitiveData {
    SensitiveEnum strategy();
}

3、自定义脱敏策略,可自行扩展

public enum SensitiveEnum {
    /**
     * 用户名
     */
    USERNAME(s -> s.replaceAll("\\S*(\\S)", "***$1")),
    /**
     * 身份证
     */
    ID_CARD(s -> s.replaceAll("(\\d{4})\\d{10}(\\w{4})", "$1****$2")),
    /**
     * 手机号
     */
    PHONE(s -> s.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2")),
    /**
     * 地址
     */
    ADDRESS(s -> s.replaceAll("(\\S{3})\\S{2}(\\S*)\\S{2}", "$1****$2****"));


    private final Function<String, String> desensitizer;

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

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

4、配置注解,指定脱敏字段【@SensitiveData(strategy = SensitiveEnum.USERNAME)】

public class SysUserQueryVO {

    @ApiModelProperty("主键ID")
    private Integer id;

    @ApiModelProperty("主键ID")
    private String username;

    @ApiModelProperty("是否启用(0启用,1禁用)")
    //@DictLabel(dictType = SysDictTypeEnum.COMMON_ENABLE)
    @EmbedTrans(dicMetohd = SysDictTypeEnum.COMMON_ENABLE)
    private Integer enable;

    @ApiModelProperty(value = "姓名")
    @SensitiveData(strategy = SensitiveEnum.USERNAME)
    private String nickname;

    @ApiModelProperty(value = "身份证")
    @SensitiveData(strategy = SensitiveEnum.ID_CARD)
    private String idCardNum;

    @ApiModelProperty(value = "联系电话")
    private String mobile;

    @ApiModelProperty(value = "门店id")
    private Integer storeId;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值