需要是对不同的层级用户配置是否进行数据脱敏,比如用户有四级,对于四到二级用户登入时,展示的数据是要脱敏的,一级用户登入时,数据无需脱敏。
脱敏的方式是用这位的写法https://blog.csdn.net/l_learning/article/details/124450886
现在数据是成功脱敏了,但是怎么配置是否进行脱敏呢。可否根据不同用户登入 然后控制注解是否生效来控制脱敏呢 怎么控制自定义注解是否生效呢
1、首先你在元注解增加一个userLevel
@Retention(RetentionPolicy.RUNTIME)
@JacksonAnnotationsInside
@JsonSerialize(using = DesensitizationJsonSerializer.class)
public @interface Desensitization {
Class<? extends AbstractDesensitization> value();
int userLevel() default 1;
}
2、然后通过这个方法获取当前对象com.fasterxml.jackson.core.JsonGenerator#getCurrentValue,在查询数据的时候,你将userLevel也查出来,在脱敏之前,根据jsonGenerator.getCurrentValue().getUserLevel和注解上的userLevel做比较,判断是否满足脱敏的条件,不满足直接返回原有数据即可。
@Override
public void serialize(String s, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException {
// System.out.println(JSONObject.toJSONString(jsonGenerator.getCurrentValue()));
jsonGenerator.writeString(desensitization.serialize(s));;
}