场景
@JsonFormat注解是属于Jackson的一个时间格式化注解,用于格式化时间。
可以在入参出参的时候就将时间格式化好。
@DateTimeFormat注解是spring的,它可以帮助我们把不是date类型的时间转成date类型。
效果
如果前端传来的为字符串格式的日期:“2022年07月29日 09时41分22秒”,则需要如下配置:
@JsonFormat(pattern = “yyyy年MM月dd日 HH时mm分ss秒”)
private Date createTime;
解析后存入DB中的则为:2023-02-23 09:46:12,查询时返回的数据则为:“2023年02月23日 09时46分12秒”
使用
1.引入依赖
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.12.6</version>
</dependency>
- 在java bean 属性上添加注解
/**
* 交易开始时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date payStartTime;
/**
* 交易结束时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date payEndTime;
3.需要指定时区
JASKSON在序列化时间时是按照国际标准时间GMT进行格式化的,而在国内默认时区使用的是CST时区,两者相差8小时,因为我们是东八区(北京时间),所以我们在格式化的时候要指定时区(timezone)。
中国时间(Asia/Shanghai) = 格林尼治时间(GMT)+ 8
格林尼治时间(GMT) = 世界协调时间(UTC) + 0
/**
* 交易开始时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private Date payStartTime;
/**
* 交易结束时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private Date payEndTime;
以上这个写法虽然可以格式化,但是并不能自动转换时间类型,需要配合@DateTimeFormat使用。
4.配合@DateTimeFormat使用
/**
* 交易开始时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
private Date payStartTime;
/**
* 交易结束时间
*/
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
private Date payEndTime;