目录

一、Spring 之 @JsonFormat 注解使用场景:将Date类型的默认时间格式通过序列化转换为我们想要的格式进行返回。

1、引入依赖 jackson 依赖,@JsonFormat 注解就在 jackson-annotations 包下,

2、如何使用 @JsonFormat  注解

 二、Spring 之 @DateTimeFormat 注解使用场景:他是将前端提交传递给后端的字符串日期时间转换为Date类型进行进行功能操作。

1、引入 Spring 及 SpringMVC 依赖,若不是SpringBoot 或 SpringCloud 最好将下方Spring相关的依赖整合起来,避免项目时存在的问题;

2、如何使用 @DateTimeFormat  注解

3、测试添加 @DateTimeFormat  注解效果,完美解决了参数传递类型转换问题。

如果不加 @DateTimeFormat 注解就报400,参数类型无法传进接口,则不会响应:

三:这里还是聊下Element-UI的一个日期时间选择器差一天问题,之前在我整理的 @InitBinder 里面看过该功能的可以跳过,想了解 @InitBinder 进行日期转换的就点击该标题跳转去看下;​​​​​​


一、Spring 之 @JsonFormat 注解使用场景:将Date类型的默认时间格式通过序列化转换为我们想要的格式进行返回。

1、引入依赖 jackson 依赖,@JsonFormat 注解就在 jackson-annotations 包下,

如果是 SpringBoot 、SpringCloud 在创建时都自动集成所以不用添加也可以,其他涉及Spring架构且并未自动集成的需要加 jackson 依赖;

        <!--添加@JsonFormat依赖-->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
            <version>2.9.6</version>
        </dependency>
        
        <!--添下面的jackson依赖,如果需要都可以加上随意-->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
            <version>2.9.6</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.9.6</version>
        </dependency>

2、如何使用 @JsonFormat  注解

(1) 在属性上加上 @JsonFormat 注解;

(2) 参数 pattern:需要转换的日期格式,当然也可以“yyyy-MM-dd HH:mm:ss”;

(3)参数 timezone:@JsonFormat注解使用的是标准的GMT时间,于北京时间差8小时,所以需要“GMT+8” 来达到北京时间同步; 

        时区(GMT)简介:格林尼治标准时间(旧译格林威治平均时间或格林威治标准时间;英语:GreenwichMeanTime,GMT)是指位于英国伦敦郊区的皇家格林尼治天文台的标准时间,也是目前的协调世界时(UTC),与北京时间慢8个小时,所以需要(GMT+8)。

3、测试注解效果,上面是去掉注解的格式,下面是注解效果;

 二、Spring 之 @DateTimeFormat 注解使用场景:他是将前端提交传递给后端的字符串日期时间转换为Date类型进行进行功能操作。

1、引入 Spring 及 SpringMVC 依赖,若不是SpringBoot 或 SpringCloud 最好将下方Spring相关的依赖整合起来,避免项目时存在的问题;

如果是 SpringBoot 、SpringCloud 在创建时都自动集成所以不用加。

<!-- 引入Spring(包含SpringMVC) 依赖 start -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-oxm</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-aop</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context-support</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-test</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-core</artifactId>
      <version>${spring.version}</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-web</artifactId>
      <version>${spring.version}</version>
    </dependency>
    <!-- 引入Spring 依赖 end -->

2、如何使用 @DateTimeFormat  注解

(1) 在属性上加上 @DateTimeFormat 注解;

(2) 参数 pattern:需要转换的日期格式,当然也可以“yyyy-MM-dd HH:mm:ss”;

3、测试添加 @DateTimeFormat  注解效果,完美解决了参数传递类型转换问题。

 

如果不加 @DateTimeFormat 注解就报400,参数类型无法传进接口,则不会响应:

 

 

三:这里还是聊下Element-UI的一个日期时间选择器差一天问题,之前在我整理的 @InitBinder 里面看过该功能的可以跳过,想了解 @InitBinder 进行日期转换的就点击该标题跳转去看下;​​​​​​

在前端日期选择器中添加:value-format="yyyy-MM-dd"  ,也可以“yyyy-MM-dd HH:mm:ss”,就可以解决使用Element-UI日期时间选择器提交数据差一天的问题。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐