我在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中缺少CountryCodeareaCodelocalNumber,仅处理基类。

    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/

10-16 05:12