前端和数据库时间差8小时?

springBoot版本:2.4.5
Mysql版本:5.7.28

原因一:

数据库配置

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/zzytest?autoReconnect=true&useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai&useAffectedRows=true
    username: root
    password: root
    driver-class-name: com.mysql.cj.jdbc.Driver

关键是这里!:

&serverTimezone=Asia/Shanghai

数据库默认是UTC(GMT +0)时间,而我们是东八区(GMT +0),差8小时,所以数据库时间和前端时间差8小时

原因二:

Web开发常用的SpringMvc默认的Json解析框架是JackSon,默认时区也是UTC,如果你也用的Jackson,也需要修改下它的默认配置
方法有好几种:

  1. 修改配置文件:
jackson:
	time-zone: GMT+8  
	date-format: yyyy-MM-dd HH:mm:ss

time-zone: GMT+8
:修改时区
date-format: yyyy-MM-dd HH:mm:ss
:这个看你需要配置,加了这个配置,字段类型为Date的,
前端传参时必须是yyyy-MM-dd HH:mm:ss格式,并且Date也会被解析成yyyy-MM-dd HH:mm:ss这样的格式

  1. 加注解:
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss" , timezone = "GMT+8")
private Date creatTime;
  1. 修改消息转换器
在这里插入代码片
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值