Spring 家族之 @JsonFormat 与 @DateTimeFormat 注解进行日期时间格式及数据类型之间的转换 (SSM 、SSMP 、SpringBoot 、SpringCloud )

目录

一、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日期时间选择器提交数据差一天的问题。

  • 20
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值