@DateTimeFormat与@JsonFormat详解

目录

一、时间传值

二、@DateTimeFormat

三、@JsonFormat


一、时间传值

前端时间控件,一般情况下直接会传一个 yyyy-MM-dd 的日期字符串到后台。这个时候如果我们直接用java.util.Date类型就无法正确接收到。或者我们从数据库里查到DateTime类型并且用java的Date类型接收并返回给前台的时候,前台也无法用yyyy-MM-dd的形式进行呈现。

这个时候,前面两种情况分别对应了@DateTimeFormat和@JsonFormat注解的使用。

二、@DateTimeFormat

该注解主要解决前端时间控件传值到后台接收准确的Date类属性的问题,我们可以在需要接收的类中对应的时间类型属性上加上@DateTimeFormat注解,并在注解中加上pattern属性,例如:

/**
 * 交货日期
 */
// @ApiModelProperty(value="交货日期",required = true)
// @NotNull(message = "交货日期不能为空", groups = {UpdateGroup.class})
@DateTimeFormat(pattern = "yyyy-MM-dd")
// @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd")
private Timestamp deliveryDate;

随后在前端对应deliveryDate传入的yyyy-MM-dd日期类型就能够按照该种格式进行转义赋值给deliveryDate的Timestamp类型。

若想按照yyyy/MM/dd的日期格式,则直接修改@DateTimeFormat的pattern属性为对应的日期格式即可,即@DateTimeFormat(pattern = “yyyy/MM/dd”)。

或者还想要接收到对应的HH-mm-ss时分秒,同样在pattern中加上即可,如@DateTimeFormat(pattern = “yyyy-MM-dd HH-mm-ss”)

三、@JsonFormat

该注解主要解决后台从数据库中取出时间类型赋予java对象的Date属性值无法在前端以一定的日期格式来呈现,默认返回的是一个带时区的格式串,不符合我们日常要呈现的yyyy-MM-dd格式的日期。
同样,我们在对应的接收对象时间类型上加上@JsonFormat注解,并在注解中加上pattern属性以及timezone属性,例如:

/**
 * 交货日期
 */
//@ApiModelProperty(value="交货日期",required = true)
//@NotNull(message = "交货日期不能为空", groups = {UpdateGroup.class})
//@DateTimeFormat(pattern = "yyyy-MM-dd")
@JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd")
private Timestamp deliveryDate;

表示我们从后台数据库查询结果赋予对应的 Timestamp 类型为 yyyy-MM-dd 格式,且注意timezone 属性,最好加上GMT+8表示我们以东八区时区为准,若读者想用其他时区就可以通过更改timezone属性来改变,从而解决时区不同造成的时间差问题。

参考:@DateTimeFormat与@JsonFormat详解_Vainycos的博客-CSDN博客_@datetimeformat和@jsonformat

你可能感兴趣的:(Web开发,java,JsonFormat,DateTimeFormat)