我在REST实现中使用genson 1.4进行JSON处理,使用genson时JSON继承不起作用。请在下面找到示例代码结构。
这是我的BaseObject
This is my BaseObject
public class SynBaseObject implements Serializable
{
private Long status;
//GettersAndSetters
}
这是我的孩子班
public class PhoneNumber extends SynBaseObject
{
private String countryCode;
private String areaCode;
private String localNumber;
//GettersAndSetters
}
这是我的回应对象
public class ResponseObject implements Serializable
{
private Integer errorCode;
private String errorMessage;
private Long primaryKey;
private SynBaseObject baseClass;
public ResponseObject()
{
}
public SynBaseObject getBaseObject()
{
return baseClass;
}
public void setBaseObject(SynBaseObject baseClass)
{
this.baseClass = baseClass;
}
public Integer getErrorCode()
{
return errorCode;
}
public void setErrorCode(Integer errorCode)
{
this.errorCode = errorCode;
}
}
这是GENSON JSON输出:
{“ baseObject”:{“ status”:null},“ errorCode”:null,“ errorMessage”:null,“ primaryKey”:null}
JSON中缺少
CountryCode
,areaCode
和localNumber
,仅处理基类。 Genson genson = new Genson();
PhoneNumber number = new PhoneNumber();
number.setCountryCode("2");
number.setAreaCode("3");
number.setLocalNumber("9645");
ResponseObject responseObject = new ResponseObject();
responseObject.setBaseObject(number);
String serialize = genson.serialize(responseObject);
System.out.println(serialize);
输出与其余服务相同。
最佳答案
默认情况下,Genson在ser / de期间使用静态类型。这意味着它将对象视为SynBaseObject的实例,而不是具体的PhoneNumber类型。
您可以通过配置告诉Genson使用运行时类型:
Genson genson = new GensonBuilder().useRuntimeType(true).create();
在这里,您可以找到有关如何customize Genson with Jaxrs的一些示例。
请注意,如果您想反序列化为ResponseObject,那么您可能会遇到麻烦,因为在json中没有有关什么是基础对象的具体类型的信息。但是,如果消耗的json也由Genson产生,则可以通过启用类元数据序列化
builder.useClassMetadata(true)
轻松解决此问题。有关Genson中handling of polymorphic类型的更多文档。
关于java - Genson 1.4(JSON)无法处理继承的Pojo的,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/38656021/