spring-boot:对日期(Date)类型数据的序列化

本文介绍了在Spring Boot中如何使用`@JsonFormat`注解处理JavaBean中的Date类型字段,以及如何全局配置Jackson序列化参数,以控制非JavaBean中的Date类型字段日期格式。通过`Jackson2ObjectMapperBuilderCustomizer`接口或者直接创建`ObjectMapper`实例,可以设置日期的ISO8601格式。此外,还提到了通过`application.properties`或`application.yml`配置文件进行日期格式和时区的全局设置。

@JsonFormat

spring将Java 数据类型的序列和反序列化为JSON字符串是依赖jackson(com.fasterxml.jackson.core:jackson-core)库来实现的,对于Java Bean中的Date类型字段,可以使用@JsonFormat注释来指定日期格式,示例如下:

    @NotNull
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonProperty("start_time")
    private Date startTime;

但是对于非类Java Bean的字段,怎么指定日期格式呢?
比如一个value中有Date类型的Map<String,Object>类型序列化时,如何控制jackson对Date类型的日期格式呢?

@Bean

可以通过如下方式配置一个bean,如下示例指定将所有Date类型序列化时生成ISO8601标准格式的字串串

    /** ISO8601时间格式 */
    private static final String ISO8601_FORMATTER_STR = "yyyy-MM-dd'T'HH:mm:ss.SSSZ";
    @Bean
    public Jackson2ObjectMapperBuilderCustomizer jacksonObjectMapperCustomization() {
    
        return jacksonObjectMapperBuilder ->
                jacksonObjectMapperBuilder.simpleDateFormat(ISO8601_FORMATTER_STR);
    }

org.springframework.boot.autoconfigure.jackson.Jackson2ObjectMapperBuilderCustomizer 接口是spring为应用层配置jackson序列化参数而定义的。通过这个接口可以指定很多jackson的特性,其中就包括关于日期类型序列的参数。

下面的通过@Bean返回一个指定了日期类型的ObjectMapper 实例也是同样的效果:

import org.springframework.context.annotation.Bean;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.TimeZone;
import com.fasterxml.jackson.databind.ObjectMapper;
	/** ISO8601时间格式 */
    private static final String ISO8601_FORMATTER_STR = "yyyy-MM-dd'T'HH:mm:ss.SSSZ";
    @Bean
    public ObjectMapper objectMapper() {
        DateFormat dateFormat = new SimpleDateFormat(ISO8601_FORMATTER_STR );
        ObjectMapper dateFormatMapper = new ObjectMapper();
        dateFormatMapper.setDateFormat(dateFormat);
        return dateFormatMapper;
    }

配置文件(全局配置)

还可以通过在application.properties中通过全局配置参数 spring.jackson.date-format, spring.jackson.time-zone 来指定日期格式和时区
application.properties

spring.jackson.date-format=yyyy-MM-dd'T'HH:mm:ss.SSSZ
spring.jackson.time-zone=GMT+8

application.yml

spring:
  jackson:
    date-format: yyyy-MM-dd'T'HH:mm:ss.SSSZ
    time-zone: GMT+8

参考资料

《Spring Jackson custom date format》
《Spring boot date 序列化问题》

### 一、Nacos Docker-Compose 部署 在构建基于 Nacos 和 Spring Cloud 的微服务架构时,首先需要完成 Nacos 的部署。根据提供的信息[^1],可以使用 Docker-Compose 来简化 Nacos 的管理。以下是完整的 `docker-compose.yml` 文件示例: ```yaml version: '3.8' services: nacos: image: nacos/nacos-server:2.0.2 container_name: nacos-server environment: - MODE=standalone ports: - "8848:8848" volumes: - ./nacos-init-data:/home/nacos/init.d restart: always ``` 上述配置文件中,`nacos` 使用了官方镜像 `nacos/nacos-server:2.0.2`,并以单机模式运行[^1]。通过绑定端口 `8848` 和挂载初始化数据目录 `/home/nacos/init.d`,可以确保 Nacos 在容器中的稳定运行。 --- ### 二、Z-Boot-Cloud 项目结构设计 以下是 Z-Boot-Cloud 项目的模块划分及功能说明: #### 1. **zboot-auth(认证服务)** - 负责用户认证和授权。 - 引入依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-oauth2</artifactId> </dependency> ``` #### 2. **zboot-gateway(网关服务)** - 提供 API 网关功能。 - 引入依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> </dependency> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>knife4j-spring-boot-starter</artifactId> <version>3.0.3</version> </dependency> ``` #### 3. **zboot-common(公共模块)** - 提供共享工具类和配置。 - 引入依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.1</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>1.2.8</version> </dependency> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.8.11</version> </dependency> <dependency> <groupId>com.alibaba.fastjson2</groupId> <artifactId>fastjson2</artifactId> <version>2.0.16</version> </dependency> ``` #### 4. **其他模块** - **RabbitMQ**:消息队列支持。 ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` - **MinIO**:对象存储支持。 ```xml <dependency> <groupId>io.minio</groupId> <artifactId>minio</artifactId> <version>8.4.3</version> </dependency> ``` - **Seata**:分布式事务支持。 ```xml <dependency> <groupId>io.seata</groupId> <artifactId>seata-spring-boot-starter</artifactId> <version>1.5.0</version> </dependency> ``` --- ### 三、完整代码示例 以下为部分模块的代码示例: #### 1. zboot-auth(认证服务) ```java package com.zboot.auth; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.oauth2.config.annotation.web.configuration.EnableResourceServer; import org.springframework.security.oauth2.config.annotation.web.configuration.ResourceServerConfigurerAdapter; @SpringBootApplication @EnableDiscoveryClient @EnableResourceServer public class AuthApplication extends ResourceServerConfigurerAdapter { public static void main(String[] args) { SpringApplication.run(AuthApplication.class, args); } @Override public void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers("/oauth/**").permitAll() .anyRequest().authenticated(); } } ``` #### 2. zboot-gateway(网关服务) ```java package com.zboot.gateway; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.gateway.filter.ratelimit.KeyResolver; import org.springframework.context.annotation.Bean; import reactor.core.publisher.Mono; @SpringBootApplication public class GatewayApplication { public static void main(String[] args) { SpringApplication.run(GatewayApplication.class, args); } @Bean public KeyResolver userKeyResolver() { return exchange -> Mono.just(exchange.getRequest().getQueryParams().getFirst("user")); } } ``` #### 3. zboot-common(公共模块) ```java package com.zboot.common.util; import cn.hutool.core.date.DateUtil; public class DateUtils { public static String formatDate(long timestamp) { return DateUtil.formatDate(timestamp); } } ``` --- ### 四、学习资料推荐 1. 官方文档:[Spring Cloud Documentation](https://spring.io/projects/spring-cloud) 2. Nacos 文档:[Nacos Official Documentation](https://nacos.io/zh-cn/docs/what-is-nacos.html) 3. MyBatis-Plus:[MyBatis-Plus Documentation](https://baomidou.com/) 4. Seata 分布式事务:[Seata GitHub](https://github.com/seata/seata) --- ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

10km

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值