将远程服务器获取的linkedhashMap对象转为实体类对象
生活随笔
收集整理的這篇文章主要介紹了
将远程服务器获取的linkedhashMap对象转为实体类对象
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
微服務中從其他服務獲取過來的對象,本來傳的是實體類對象 , 但是接受到的參數卻是linkedhashMap類型的對象 , 如果強轉成自定義的實體類型會報錯,因此可以利用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)轉載:https://www.cnblogs.com/badboyf/p/6126511.html
總結
以上是生活随笔為你收集整理的将远程服务器获取的linkedhashMap对象转为实体类对象的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MyBatis Plus自定义SQL使用
- 下一篇: vue引入组件时‘@/xxxx’的意思