java 时间参数注解@DatetimeFormat和@JsonFormat

背景:从数据库获取时间传到前端进行展示的时候,我们有时候可能无法得到一个满意的时间格式的时间日期,在数据库中显示的是正确的时间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了这个问题,我们通过使用@JsonFormat可以很好的解决:后台到前台时间格式保持一致的问题,其次,另一个问题是,我们在使用WEB服务的时,可能会需要用到,传入时间给后台,比如注册新用户需要填入出生日期等,这个时候前台传递给后台的时间格式同样是不一致的,而我们的与之对应的便有了另一个注解,@DataTimeFormat便很好的解决了这个问题,接下来记录一下具体的@JsonFormat与DateTimeFormat的使用过程。

1.注解@JsonFormat(出参格式化)

1.在你需要查询出来的时间的数据库字段对应的实体类的属性上添加@JsonFormat

import java.util.Date;
 
import com.fasterxml.jackson.annotation.JsonFormat;
 
public class TestClass {
 
    //设置时区为上海时区,时间格式自己据需求定。
    @JsonFormat(pattern="yyyy-MM-dd",timezone = "GMT+8")
    private Date testTime;
 
    
    public Date gettestTime() {
        return testTime;
    }
 
    public void settestTime(Date testTimee) {
        this.testTime= testTime;
    }
}

这里解释一下:@JsonFormat(pattern=“yyyy-MM-dd”,timezone = “GMT+8”)

pattern:是你需要转换的时间日期的格式

timezone:是时间设置为东八区,避免时间在转换中有误差

提示:@JsonFormat注解可以在属性的上方,同样可以在属性对应的get方法上,两种方式没有区别

2.完成上面操作之后,我们用对应的实体类来接收数据库查询出来的结果时就完成了时间格式的转换,再返回给前端时就是一个符合我们设置的时间格式了

2.注解@DateTimeFormat(入参格式化)

1.在controller层我们使用spring mvc 表单自动封装映射对象时,我们在对应的接收前台数据的对象的属性上加@DateTimeFormat

@GetMapping("/test3")
    public void test3(DateTest dateTest) {
        logger.info("日期:{}", dateTest.getDateTest());
    }
public class DateTest {

    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private Date dateTest;
    
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private Date dateTest2;

    public Date getDateTest() {
        return dateTest;
    }

    public void setDateTest(Date dateTest) {
        this.dateTest = dateTest;
    }

    public Date getDateTest2() {
        return dateTest2;
    }

    public void setDateTest2(Date dateTest2) {
        this.dateTest2 = dateTest2;
    }
}

这里我两个注解都同时使用了,因为我既需要取数据到前台,也需要前台数据传到后台,都需要进行时间格式的转换,可以同时使用

2.在controller层我们用get请求获取单个日期字段时,如果不进行处理则会报400,加上@DateTimeFormat则会解决此问题

@GetMapping("/test2")
    public void test2(@RequestParam @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date date) {
        logger.info("日期:{}", date);
    }

3.在controller层我们用post请求映射对象时,我们需要在对应的接收前台数据对象的属性上加@JsonFormat,这时不能单独使用@DateTimeFormat,否则会报错

@GetMapping("/test4")
    public void test4(@RequestBody DateTest dateTest) {
        logger.info("日期:{}", dateTest.getDateTest2());
    }
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private Date dateTest2;
  • 11
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: @datetimeformat和@jsonformat是Spring Boot中的注解,用于格式化日期和时间以及JSON数据的输出格式。 @datetimeformat注解可以用于将日期和时间格式化为指定的格式,例如: ```java @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date createTime; ``` 这将把createTime字段格式化为"yyyy-MM-dd HH:mm:ss"的日期和时间格式。 @jsonformat注解可以用于指定JSON数据的输出格式,例如: ```java @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8") private Date createTime; ``` 这将把createTime字段格式化为"yyyy-MM-dd HH:mm:ss"的日期和时间格式,并且时区为GMT+8。 使用这些注解可以方便地控制日期和时间的格式化以及JSON数据的输出格式,提高代码的可读性和可维护性。 ### 回答2: @datetimeformat和@jsonformat都是Spring Boot框架中的注解。 @datetimeformat是一个用于格式化日期和时间注解,在Spring MVC的表单处理器和@ResponseBody方法中经常使用。该注解可以将输入的字符串转换为Java Date类型,并将输出的日期格式化为指定的格式。例如,我们可以使用@datetimeformat("yyyy-MM-dd HH:mm:ss")将接收到的字符串转换为yyyy-MM-dd HH:mm:ss格式的日期类型。 @jsonformat是一个用于格式化JSON数据的注解。它可以在Java对象序列化为JSON格式时,指定日期类型、数字类型、布尔类型等数据类型的格式化方式。例如,我们可以使用@jsonformat(pattern="yyyy-MM-dd HH:mm:ss")将Date类型转换为yyyy-MM-dd HH:mm:ss格式的字符串,以便在前端以JSON格式显示。 除了格式化日期和时间之外,@datetimeformat和@jsonformat还可以用于其他数据类型的格式化。例如,@datetimeformat可以用于格式化国际化货币、数字格式,而@jsonformat可以用于格式化枚举类型、BigDecimal类型等。 总之,@datetimeformat和@jsonformat都是非常实用的注解,可以帮助我们轻松地格式化日期、时间和其他数据类型,让我们的代码更加清晰、易读和易懂。 ### 回答3: 两个注解的作用都是将数据格式化后输出。 @datetimeformat主要用于格式化日期类型的数据,可以将日期类型转化为指定的格式输出。使用该注解需要在实体类中的日期字段上添加注解,指定日期格式,例如: ``` @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date createTime; ``` @jsonformat则用于将对象转化为JSON格式输出。使用该注解需要在实体类的字段上添加注解,指定JSON格式的日期格式、数字格式、对象格式等,例如: ``` @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8") private Date createTime; ``` 这样,在通过JSON格式输出该对象时,createTime字段将会按照指定的格式进行格式化输出。 这两个注解在实际开发中非常常用,可以使得输出的数据更加规范和易读。特别是在前后端分离的开发中,JSON格式的数据交互更是必不可少。因此,掌握这两个注解的使用是Java开发工程师必须具备的基本技能之一。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值