一、什麼是ObjectMapper?
- ObjectMapper類是Jackson庫的主要類,它提供一些功能將資料集或物件轉換的實現。
- 它將使用JsonParser和JsonGenerator例項來實現JSON的實際讀/寫。
二、ObjectMapper怎麼使用?
2.1 配置
2.1.1 普通Java專案(引入如下依賴即可)
<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.9.5</version> </dependency> <!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-core --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.9.5</version> </dependency> <!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-annotations --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>2.9.5</version> </dependency>
2.1.2 Sring Boot專案
重要說明:
由於Spring Boot的自動配置JacksonAutoConfiguration中有如下圖所示的依賴引入和配置,所以不需要我們額外配置
2.2 實戰
User類
1 @Data 2 @EqualsAndHashCode(callSuper = false) 3 @Accessors(chain = true) 4 public class User implements Serializable { 5 6 private static final long serialVersionUID = 1L; 7 8 // 姓名 9 private String name; 10 11 // 性別 12 private String sex; 13 14 // 年齡 15 private Integer age; 16 }
2.2.1 Java物件、集合轉JSON
1 public static void main(String[] args) throws IOException { 2 3 ObjectMapper objectMapper = new ObjectMapper(); 4 5 User user = new User(); 6 user.setName("張三"); 7 user.setAge(20); 8 user.setSex("男"); 9 10 List<User> userList = new ArrayList<>(); 11 userList.add(user); 12 13 // 物件轉換為JSON 14 String userJsonString = objectMapper.writeValueAsString(user);16 17 // 集合轉換為JSON 18 String userListJsonString = objectMapper.writeValueAsString(userList);20 }
2.2.2 JSON轉Java物件、集合
1 // JOSN轉物件(java物件) 2 User newUser = objectMapper.readValue(userJsonString, User.class); 3 4 // JOSN轉集合(集合) 5 List<User> list = objectMapper.readValue(userListJsonString, new TypeReference<List<User>>(){});
2.2.3 json轉JsonNode、ObjectNode
說明:
Jackson的JsonNode和ObjectNode兩個類,前者是不可變的,一般用於讀取。後者可變,一般用於建立Json物件圖。
1 // json轉JsonNode 2 JsonNode jsonNode = objectMapper.readTree(userJsonString); 3 String sex = jsonNode.get("sex").asText(); 4 5 // JsonNode轉ObjectNode 6 ObjectNode objectNode = (ObjectNode)jsonNode; 7 8 // json轉JsonNode 9 JsonNode jsonNodeList = objectMapper.readTree(userListJsonString); 10 11 // JsonNode轉ObjectNode 12 ArrayNode arrayNode = (ArrayNode)jsonNodeList;
2.2.4 jsonNode轉物件、集合
1 // jsonNode轉為json字串 2 String jsonNodeString = objectMapper.writeValueAsString(jsonNode); 3 String jsonNodeListString = objectMapper.writeValueAsString(jsonNodeList); 4 5 // json字串轉物件、集合 6 User user1 = objectMapper.readValue(jsonNodeString, User.class); 7 List<User> list1 = objectMapper.readValue(jsonNodeListString, new TypeReference<List<User>>() {});
2.3 注意事項
2.3.1 微服務中從其他服務獲取過來的物件,如果從Object強轉為自定義的型別會報錯,利用ObjectMapper轉換。
正確示例:
說明:Schedule類、OutpOrderBill類都是類似於User類的Java物件。
// 物件 Schedule schedule = objectMapper.convertValue(callNurseCenterService.getSchedule(registRecord.getScheCode()).getData(), Schedule.class); // 泛型為物件的集合 List<OutpOrderBill> outpOrderBillList = objectMapper.convertValue( callChargeCenterService.getOrderBillByOrderCode(orders.getOrgCode(),orders.getOrderCode()).getData(), new TypeReference<List<OutpOrderBill>>() {});
2.3.2 上面轉換的過程中,如果返回的欄位你不是都需要,需要忽略其中的幾個欄位,在自定義的類中新增標紅註解
1 @Data 2 @EqualsAndHashCode(callSuper = false) 3 @Accessors(chain = true) 4 @JsonIgnoreProperties(ignoreUnknown = true) 5 public class User implements Serializable { 6 7 private static final long serialVersionUID = 1L; 8 9 ////提供有這個引數,但是不想獲取 10 // // 姓名 11 // private String name; 12 13 // 性別 14 private String sex; 15 16 // 年齡 17 private Integer age; 18 }
如果不想新增註解,可以使用下面兩種方式
第一種方式:
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);
2.3.3 在轉換的過程中,有可能有的屬性被設成空就不序列化等的需求,可以在類的屬性上或直接在類上加上一下註解。用在屬性上就是隻針對一個屬性,用在類上就是針對類裡的所有屬性。
@JsonInclude(Include.NON_NULL)
@JsonInclude(Include.Include.ALWAYS) 預設
@JsonInclude(Include.NON_DEFAULT) 屬性為預設值不序列化
@JsonInclude(Include.NON_EMPTY) 屬性為 空(“”) 或者為 NULL 都不序列化
@JsonInclude(Include.NON_NULL) 屬性為NULL 不序列化
參考網址: