一、修改出参注解
@JsonSerialize
使用场景,例:给前端返回手机号进行脱敏操作
1、添加脱敏工具类
/**
* 对字符串进行脱敏操作
*
* @param origin 原始字符串
* @param prefixNoMaskLen 左侧需要保留几位明文字段
* @param suffixNoMaskLen 右侧需要保留几位明文字段
* @param maskStr 用于遮罩的字符串, 如'*'
* @return 脱敏后结果
*/
public static String desValue(String origin, int prefixNoMaskLen, int suffixNoMaskLen, String maskStr) {
if (origin == null) {
return null;
}
StringBuilder sb = new StringBuilder();
for (int i = 0, n = origin.length(); i < n; i++) {
if (i < prefixNoMaskLen) {
sb.append(origin.charAt(i));
continue;
}
if (i > (n - suffixNoMaskLen - 1)) {
sb.append(origin.charAt(i));
continue;
}
sb.append(maskStr);
}
return sb.toString();
}
2、新建一个类继承JsonDeserializer
public class MyJsonSerializer extends JsonSerializer<List<Integer>> {
@Override
public void serialize(
List<Integer> stateList, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException {
String join = StringUtils.join(stateList, ",");
jsonGenerator.writeString(join);
}
}
3、对应得实体类字段上添加注解
@JsonSerialize(using = EncryptionJsonSerializer.class)
private String phone;
二、修改入参注解
@JsonDeserialize
使用场景,例:如果前端传入参数报错指定字符,边将其移除
1、新建一个类继承JsonDeserializer
public class RemoveUrlPrefixJsonDeserializer extends JsonDeserializer<String> {
@Value("${ip}")
public String ip;
@Override
public String deserialize(JsonParser jsonParser, DeserializationContext context) throws IOException {
String text = jsonParser.getText();
if (text != null && text.contains(ip)){
text = text.replace(ip,"");
}
return text;
}
}
2、使用注解
@JsonDeserialize(using = RemoveUrlPrefixJsonDeserializer.class)
private String faceImage;