我希望为同一对象提供多个杰克逊反序列化器,所有这些都基于自定义注释。
理想情况下,我有一个 POJO,例如:
public class UserInfo {
@Redacted
String ssn;
String name;
}
在“正常”条件下,我希望该对象以默认方式序列化:
{"ssn":"123-45-6789", "name":"Bob Smith"}
但为了记录目的(例如),我想编辑 SSN,这样它就不会保存在我们的日志中:
{"ssn":"xxx-xx-xxxx", "name":"Bob Smith"}
我也研究过使用@JsonSerialize并提出:
public class UserInfo {
@JsonSerialize(using = RedactedSerializer.class, as=String.class)
String firstName;
String lastName;
}
问题是它总是使用这个规则。是否可以添加多个@JsonSerializer,并且在运行时代码中仅使用指定的一个?
我也看到了“视图”,但理想情况下,我至少想表明该字段存在于请求中 - 即使我不知道其值。
100% 安全的方法是在不同的请求中使用不同的 DTO。但是,是的,如果你不能这样做,请使用@JsonView
和自定义序列化器,例如:
class Views {
public static class ShowSSN {}
}
private static class MyBean{
@JsonSerialize(using = MyBeanSerializer.class)
@JsonView(Views.ShowSSN.class)
String ssn;
//getter setter constructor
}
private class MyBeanSerializer extends JsonSerializer<String> {
@Override
public void serialize(String value, JsonGenerator gen,
SerializerProvider serializers) throws IOException {
Class<?> jsonView = serializers.getActiveView();
if (jsonView == Views.ShowSSN.class)
gen.writeString(value); // your custom serialization code here
else
gen.writeString("xxx-xx-xxxx");
}
}
并像这样使用它:
public static void main(String[] args) throws JsonProcessingException {
ObjectMapper mapper = new ObjectMapper();
MyBean bean = new MyBean("123-45-6789");
System.out.println(mapper.writerWithView(Views.ShowSSN.class)
.writeValueAsString(bean));
// results in {"ssn":"123-45-6789"}
System.out.println(mapper.writeValueAsString(bean));
// results in {"ssn":"xxx-xx-xxxx"}
}
另外,例如在春天,它会非常容易使用
@Controller
public class MyController {
@GetMapping("/withView") // results in {"ssn":"123-45-6789"}
@JsonView(Views.ShowSSN.class)
public @ResponseBody MyBean withJsonView() {
return new MyBean("123-45-6789");
}
@GetMapping("/withoutView") // results in {"ssn":"xxx-xx-xxxx"}
public @ResponseBody MyBean withoutJsonView() {
return new MyBean("123-45-6789");
}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)