1.记录一段序列化RESTful API接受时间格式的代码
注册Bean之后可以无需使用@JsonFormat注解
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.15.2</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.15.2</version>
</dependency>
/**
* 配置并返回一个ObjectMapper实例
* 该实例用于处理JSON数据的序列化和反序列化
* 通过自定义配置,可以更好地控制JSON处理过程
*/
@Bean
public ObjectMapper objectMapper(Jackson2ObjectMapperBuilder builder) {
// 构建ObjectMapper实例
ObjectMapper objectMapper = builder.build();
// 禁用将日期写入为时间戳的形式
// 这样做是为了统一日期时间的处理方式,避免在JSON序列化过程中出现不一致的情况
objectMapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
// 注册JavaTimeModule模块,以支持Java 8中的日期时间API
// 这是为了使ObjectMapper能够处理Java 8引入的新日期时间类型
objectMapper.registerModule(new JavaTimeModule());
// 设置日期格式为"yyyy-MM-dd HH:mm:ss"
// 通过设置日期格式,确保在序列化和反序列化时,日期时间信息的格式保持一致
objectMapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"));
return objectMapper;
}
@JsonFormat使用:
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss")
序列化Event时,会将occurredAt字段系列化为"yyyy-MM-dd HH:mm:ss"格式的字符串
@DateTimeFormat使用:
@DateTimeFormat(pattern = "yyyy-MM-dd")
区别:
2.快速去除一个数组里面的重复元素
Arrays.stream(names).distinct().toArray(String[]::new)
3.快速统计当前项目的所有依赖关系和版本
mvn dependency:tree > tree.txt
4.设置JVM运行参数
java -Xms1536m -Xmx3072m -jar Hello.jar