Jackson消息转换器

2024-08-23 02:44
文章标签 消息 转换器 jackson

本文主要是介绍Jackson消息转换器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Jackson

json的概念

json是一种应用广泛的数据交换格式,例如:

{"name": "admin","age": 20,"hobbies":["唱","跳","rap"]
}

Jackson就是将Java对象与Json数据进行相互转换的工具。

public class {private String name;private int age;private String[] hobbies
}

Jackson是Spring默认使用的Json转化器,有依赖少,稳定性高,API丰富等优点

使用方法:

引入依赖

<dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-core</artifactId>
</dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-annotations</artifactId>
</dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId>
</dependency>
<!--对LocalDateTime等jdk8时间日期api的转化支持-->
<dependency><groupId>com.fasterxml.jackson.datatype</groupId><artifactId>jackson-datatype-jsr310</artifactId><version>2.10.1</version>
</dependency>

如果采用Spring boot框架开发,会自动引入Jackson的全部依赖

1. 序列化

Jackson需要使用ObjectMapper进行序列化,并且他是线程安全的,可以设定为成员变量

@SpringBootTest
class JacksonApplicationTests {private static final String DATE_TIME_FORMAT = "yyyy-MM--dd HH:mm:ss";//json转化器private static ObjectMapper objectMapper = new ObjectMapper();//全局配置序列化static {//设置为不包含null值objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);//对于单个的bean进行配置可以在其实体类上添加@JsonInclude(JsonInclude.Include.NON_NULL)注解}/*** 序列化*/@Testvoid serializeTest() throws JsonProcessingException {User user = new User();String[] hobbies = {"sing","dance","rap"};//Jackson默认包含null值//user.setId(1L);user.setUsername("kunkun");user.setAge(22);user.setHobbies(hobbies);user.setRegisterDate(new Date());user.setBirthday(LocalDateTime.now());String json = objectMapper.writeValueAsString(user);System.out.println(json);}
}

2.对于日期格式化

//首先可以在实体类上添加注解
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
private Date registerDate;@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "GMT+8")
private LocalDateTime birthday;//修改全局配置
//自动通过spi发现jackson的module并注册
objcetMapper.findAndRegisterModules();
//手动配置JavaTimeModule
JavaTimeModule javaTimeModule = new JavaTimeModule( );
javaTimeModule.addSerializer(LocalDateTime.classnew LocalDateTimeSerializer(DateTimeFormatter.ofPattern(DATE_TIME_FORMAT)));
javaTimeModule.addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(DATE_TIME_FORMAT)));
//注册
objectMapper.registerModule(javaTimeModule);

3. 反序列化

//前端传来的json字符串
String str = "Json字符串";
//需要传入json和指定的反序列化类型
User usedr = objectMapper.readValue(str, User.class);//忽略不存在的key,当json中含有实体类中不存在的属性,忽略
//FastJson默认就选择忽略
//在静态代码块中配置属性,这两种写法都可以
objectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES,false);
objectMapper.disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);//对泛型的处理
String str = "前端传来的带有泛型的json";ResultDTO<User> userResultDTO = objectMapper.readValue(str, new TypeReference<ResultDTO<User>>()) {};

4. 通用配置

//通用配置统一在静态代码块中
//驼峰转下划线  userName <---> user_name
objectMapper.setPropertyNamingStrategy(PropertyNamingStrategy.SNAKE_CASE);//在实体类上标注@JsonIgnore  表示忽略该属性
@JsonIgnore
private String password;

5. 对象更新

//对象更新,如果后者有值,则使用后者,否则前者的值不变
@Test
void test() throws Exception {User originalUser = new User();originalUser.setId(1L);originalUser.setName("Angelday");originalUser.setAge(21);User newUser = new User();newUser.setId(2L);newUser.setAge(22);User updatedUser = objectMapper.updateValue(originalUser, newUser);//id: 2 name: Angelday age: 22System.out.println(updatedUser);
}

应用

我们自定义的Jackson配置信息可以写到配置文件中

# 设置日期格式  
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss  # 设置时区  
spring.jackson.time-zone=Asia/Shanghai  # 忽略无法识别的字段  
spring.jackson.deserialization.fail-on-unknown-properties=false  # 忽略空值字段  
spring.jackson.default-property-inclusion=non_null
spring:  jackson:  date-format: yyyy-MM-dd HH:mm:ss  time-zone: Asia/Shanghai  deserialization:  fail-on-unknown-properties: false  default-property-inclusion: non_null

也可以自定义ObjectMapper Bean,SpringBoot会自动使用这个Bean来替代默认的ObjectMapper

@Configuration
public class JacksonConfig {  @Bean  public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {  return builder  .serializationInclusion(JsonInclude.Include.NON_NULL) //忽略空值  .featuresToDisable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS) //禁用时间戳 // 可以添加更多的自定义配置  .build();  }
}

这篇关于Jackson消息转换器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1098126

相关文章

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Springboot中Jackson用法详解

《Springboot中Jackson用法详解》Springboot自带默认json解析Jackson,可以在不引入其他json解析包情况下,解析json字段,下面我们就来聊聊Springboot中J... 目录前言Jackson用法将对象解析为json字符串将json解析为对象将json文件转换为json

SpringBoot 自定义消息转换器使用详解

《SpringBoot自定义消息转换器使用详解》本文详细介绍了SpringBoot消息转换器的知识,并通过案例操作演示了如何进行自定义消息转换器的定制开发和使用,感兴趣的朋友一起看看吧... 目录一、前言二、SpringBoot 内容协商介绍2.1 什么是内容协商2.2 内容协商机制深入理解2.2.1 内容

ActiveMQ—消息特性(延迟和定时消息投递)

ActiveMQ消息特性:延迟和定时消息投递(Delay and Schedule Message Delivery) 转自:http://blog.csdn.net/kimmking/article/details/8443872 有时候我们不希望消息马上被broker投递出去,而是想要消息60秒以后发给消费者,或者我们想让消息没隔一定时间投递一次,一共投递指定的次数。。。 类似

Java消息队列:RabbitMQ与Kafka的集成与应用

Java消息队列:RabbitMQ与Kafka的集成与应用 大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿! 在现代的分布式系统中,消息队列是实现系统间通信、解耦和提高可扩展性的重要组件。RabbitMQ和Kafka是两个广泛使用的消息队列系统,它们各有特点和优势。本文将介绍如何在Java应用中集成RabbitMQ和Kafka,并展示它们的应用场景。 消息队

css选择器和xpath选择器在线转换器

具体前往:Css Selector(选择器)转Xpath在线工具

Kafka 分布式消息系统详细介绍

Kafka 分布式消息系统 一、Kafka 概述1.1 Kafka 定义1.2 Kafka 设计目标1.3 Kafka 特点 二、Kafka 架构设计2.1 基本架构2.2 Topic 和 Partition2.3 消费者和消费者组2.4 Replica 副本 三、Kafka 分布式集群搭建3.1 下载解压3.1.1 上传解压 3.2 修改 Kafka 配置文件3.2.1 修改zookeep