有没有办法不仅可以通过在@JsonView中使用不同的类来查看/隐藏字段,还可以根据每个字段分别使用的视图定义不同的名称(比如@JsonProperty)?
Greets&谢谢! 添
答案 0 :(得分:3)
我的解决方案涉及Jackson Mixin功能 我使用相同的视图类来放置不同的@jsonProperty注释。这比单独的类更方便,但是,现在你不能使用视图的继承。如果需要,您必须创建包含@jsonProperty注释的单独类,并相应地更改mixin模块。
以下是要序列化的对象:
public class Bean
{
@JsonView({Views.Public.class, Views.Internal.class})
public String name;
@JsonView(Views.Internal.class)
public String ssn;
}
带有json属性注释的视图
public class Views
{
public static class Public {
@JsonProperty("public_name")
public String name;
}
public static class Internal {
@JsonProperty("internal_name")
public String name;
}
}
杰克逊要求的mixin模块:
@SuppressWarnings("serial")
public class PublicModule extends SimpleModule
{
public PublicModule() {
super("PublicModule");
}
@Override
public void setupModule(SetupContext context)
{
context.setMixInAnnotations(Bean.class, Views.Public.class);
}
}
@SuppressWarnings("serial")
public class InternalModule extends SimpleModule
{
public InternalModule() {
super("InternalModule");
}
@Override
public void setupModule(SetupContext context)
{
context.setMixInAnnotations(Bean.class, Views.Internal.class);
}
}
测试方法:
public static void main(String[] args)
{
Bean bean = new Bean();
bean.name = "my name";
bean.ssn = "123-456-789";
ObjectMapper mapper = new ObjectMapper();
System.out.println(args[0] + ": ");
try {
if (args[0].equals("public")) {
mapper.registerModule(new PublicModule());
mapper.writerWithView(Views.Public.class).writeValue(System.out, bean);
} else {
mapper.registerModule(new InternalModule());
mapper.writerWithView(Views.Internal.class).writeValue(System.out, bean);
}
} catch (IOException e) {
e.printStackTrace();
}
}
输出两个单独的调用:
public:
{"public_name":"my name"}
internal:
{"ssn":"123-456-789","internal_name":"my name"}