微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Java使用ObjectMapper的简单示例

这篇文章主要介绍了Java使用ObjectMapper的简单示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、什么是ObjectMapper?

ObjectMapper类是Jackson库的主要类,它提供一些功能将数据集或对象转换的实现。

它将使用JsonParser和JsonGenerator实例来实现JSON的实际读/写。

二、ObjectMapper怎么使用?

2.1 配置

2.1.1 普通Java项目(引入如下依赖即可)

com.fasterxml.jackson.corejackson-databind2.9.5com.fasterxml.jackson.corejackson-core2.9.5com.fasterxml.jackson.corejackson-annotations2.9.5

2.1.2 Sring Boot项目

重要说明:

由于Spring Boot的自动配置JacksonAutoConfiguration中有如下图所示的依赖引入和配置,所以不需要我们额外配置

2.2 实战

User类

@Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) public class User implements Serializable { private static final long serialVersionUID = 1L; // 姓名 private String name; // 性别 private String sex; // 年龄 private Integer age; }

2.2.1 Java对象、集合转JSON

public static void main(String[] args) throws IOException { ObjectMapper objectMapper = new ObjectMapper(); User user = new User(); user.setName("张三"); user.setAge(20); user.setSex("男"); List userList = new ArrayList(); userList.add(user); // 对象转换为JSON String userjsonString = objectMapper.writeValueAsstring(user); // 集合转换为JSON String userListJsonString = objectMapper.writeValueAsstring(userList); }

2.2.2 JSON转Java对象、集合

// JOSN转对象(java对象) User newUser = objectMapper.readValue(userjsonString, User.class); // JOSN转集合(集合) List list = objectMapper.readValue(userListJsonString, new TypeReference>(){});

2.2.3json转JsonNode、ObjectNode

说明:

Jackson的JsonNode和ObjectNode两个类,前者是不可变的,一般用于读取。后者可变,一般用于创建Json对象图。

// json转JsonNode JsonNode jsonNode = objectMapper.readTree(userjsonString); String sex = jsonNode.get("sex").asText(); // JsonNode转ObjectNode ObjectNode objectNode = (ObjectNode)jsonNode; // json转JsonNode JsonNode jsonNodeList = objectMapper.readTree(userListJsonString); // JsonNode转ObjectNode ArrayNode arrayNode = (ArrayNode)jsonNodeList;

2.2.4 jsonNode转对象、集合

// jsonNode转为json字符串 String jsonNodeString = objectMapper.writeValueAsstring(jsonNode); String jsonNodeListString = objectMapper.writeValueAsstring(jsonNodeList); // json字符串转对象、集合 User user1 = objectMapper.readValue(jsonNodeString, User.class); List list1 = objectMapper.readValue(jsonNodeListString, new TypeReference>() {});

2.3 注意事项

2.3.1微服务中从其他服务获取过来的对象,如果从Object强转为自定义的类型会报错,利用ObjectMapper转换。

正确示例:

说明:Schedule类、OutpOrderBill类都是类似于User类的Java对象。

// 对象 Schedule schedule = objectMapper.convertValue(callNurseCenterService.getSchedule(registRecord.getScheCode()).getData(), Schedule.class); // 泛型为对象的集合 List outpOrderBillList = objectMapper.convertValue( callChargeCenterService.getorderBillByOrderCode(orders.getorgCode(),orders.getorderCode()).getData(), new TypeReference>() {});

2.3.2 上面转换的过程中,如果返回的字段你不是都需要,需要忽略其中的几个字段,在自定义的类中添加标红注解

@Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) @JsonIgnoreProperties(ignoreUnkNown = true) public class User implements Serializable { private static final long serialVersionUID = 1L; ////提供有这个参数,但是不想获取 // // 姓名 // private String name; // 性别 private String sex; // 年龄 private Integer age; }

如果不想添加注解,可以使用下面两种方式

第一种方式:

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 不序列化

参考网址:

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐