ObjectMapper處理從遠程獲取的Object對象


微服務中從其他服務獲取過來的對象,如果從Object強轉為自定義的類型會報錯,利用ObjectMapper轉換。

ObjectMapper mapper = new ObjectMapper();
DefaultResponse defaultResponse = proxy.getData();
List<Resource> resources = (<Resource>) defaultResponse.getData();  //這里的場景是:data是一個Object類型的,但是它其實是一個List<Resouce>,想把List中的每個對象分別轉成可用的對象
for (int i = 0; i < serviceDateResources.size(); i++) {
    Resource resource = mapper.convertValue(resources.get(i), Resource.class);   //經過這步處理,resource就是可用的類型了,如果不轉化會報錯
} 

上面轉換的過程中,如果返回的字段你不是都需要,需要忽略其中的幾個字段,在自定義的類中添加如下:

import org.codehaus.jackson.annotate.JsonIgnoreProperties;

@JsonIgnoreProperties(ignoreUnknown = true)
public class Resource {
//  private Integer orderId; //提供有這個參數,但是不想獲取
  private Integer otrerFiled;
}

或者下面方法:這兩種方法不用添加注解

一:ObjectMapper mapper = new ObjectMapper().setVisibility(JsonMethod.FIELD,Visibility.ANY);
   mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
二:ObjectMapper objectMapper = new ObjectMapper();
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);

 

ObjectMapper可以實現對象到json等其他格式的互轉。如果向將java對象轉成Json格式,可以用:

ObjectMapper mapper = new ObjectMapper();
mapper.writeValueAsString(object);

會有JsonProcessingException異常,需要自己處理。在轉換的過程中,有可能有的屬性被設成空就不序列化等的需求,可以在類的屬性上或直接在類上加上一下注解。用在屬性上就是只針對一個屬性,用在類上就是針對類里的所有屬性。

@JsonInclude(Include.NON_NULL) 
@JsonInclude(Include.Include.ALWAYS) 默認 
@JsonInclude(Include.NON_DEFAULT) 屬性為默認值不序列化 
@JsonInclude(Include.NON_EMPTY) 屬性為 空(“”) 或者為 NULL 都不序列化 
@JsonInclude(Include.NON_NULL) 屬性為NULL 不序列化 

 

json轉成Object 及 Object轉json

    DefaultResponse  response = mapper.readValue(result, DefaultResponse.class); 
  String Json =  mapper.writeValueAsString(student1); 

 mapper.readValue()過程中,如果result中的字段比DefaultResponse字段多會報錯,忽略多余的字段在DefaultResponse中添加下面注解。

@JsonIgnoreProperties(ignoreUnknown = true)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。