当一个实体被外键调用时,我需要序列化一个只有两列的实体。我正在Wildfly工作,所以我正在寻找杰克逊解决方案。
假设我有实体类A
public class B{
private Long id;
private String name;
private A parent;
}
和另一个班级B:
@JsonIdentityInfo(generator=ObjectIdGenerators.PropertyGenerator.class, property="id")
@JsonIdentityReference(alwaysAsId=true)
private A parent;
当我搜索A时,我想用他的所有字段序列化A,但是当我需要检索B的istance时,我只需要两个字段(ID和标签)
如果我使用注释:
B: {
"id" : 1,
"name" : "test",
"parent" : {
"id" : 1,
"name" : 2
}
}
我只会返回id。
我想要的结果将是:
dp
答案 0 :(得分:2)
您可以使用JsonIgnoreProperties注释来禁用序列化(和反序列化)的特定字段:
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
public class B {
private Long id;
private String name;
@JsonIgnoreProperties({"anotherinfo", "foo"})
private A parent;
答案 1 :(得分:1)
让A
扩展另一个课程,比如C
:
class C {
Long id;
String name;
}
class A extends C {
String anotherinfo;
String foo;
...
}
然后,在B
:
class B {
Long id;
String name;
@JsonSerialize(as=C.class)
A parent;
}
序列化B
时,其parent
字段将只包含C
中的字段,但您序列化A
对象的其他任何地方都会显示所有字段来自A
和C
。
有关详细信息,请查看https://github.com/FasterXML/jackson-annotations#annotations-for-choosing-moreless-specific-types
答案 2 :(得分:1)
解决了添加Json Serializer的问题。
我为父类创建了一个NationJsonSerializer:
public class NationJsonSerializer extends JsonSerializer<TNation> {
@Override
public void serialize(TNation value, JsonGenerator jgen, SerializerProvider provider)
throws IOException, JsonProcessingException {
jgen.writeStartObject();
jgen.writeNumberField("id", value.getId());
jgen.writeStringField("name", value.getComune());
jgen.writeStringField("iso", value.getCap());
jgen.writeEndObject();
}
}
然后,在城市课上,我把注释
@JoinColumn(name = "idtnation",referencedColumnName = "id",nullable = true)
@ManyToOne(targetEntity = TNation.class, fetch = FetchType.EAGER)
@JsonSerialize(using = NationJsonSerializer.class)
private TNation nation;
所以,如果我使用方法Nation n = getNation(long id);我将收到所有列,但如果我使用getCity(),我将收到一个简化版本。