Spring boot各种Date时间相差8小时出现的问题及其解决方法!

文章讲述了Springboot项目中,由于数据库(Oracle)存储的时间与前端显示(+08:00时区)存在8小时差距的问题。通过调整`application.yml`中的时区设置和实体类的`@JsonFormat`,以及数据库连接参数,解决了这个跨时区问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
数据库中存的是2019-07-22 22:00:00 但是页面展示2019-07-22 14:00:00
查看数据时区是+08:00导致的,数据库是Oracle,生成数据库没办法改时区

一:Spring boot @ResponseBody转换JSON 时 Date 时间相差8小时
一描述:当使用jackson时,返回的json和数据库会相差8个小时,(亲测);
在这里插入图片描述
数据库和postman相差8个小时,debug后发现是jackson得问题。
二、解决办法:

两种方法
方法一
#application.yml文件配置
spring:
    jackson:
        time-zone: GMT+8

方法二
这样也可以解决,在你的时间上设置时间格式化。
public class Vo {
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private Date createTime;
}

mysql从数据库查询的时间与实际时间相差8小时

一解决办法:
1、spring.datasource.url=jdbc:mysql://10.35.105.25:3306/database?characterEncoding=utf-8&serverTimezone=GMT%2B8
数据库配置后面加上&serverTimezone=GMT%2B8
2、设置spring配置文件

#application.yml文件配置
spring:
  jackson:
    time-zone: GMT+8
    date-format: yyyy-MM-dd HH:mm:ss

总之,第一步为设置数据库时间为东八区(北京)时间,保证debug时候从数据库查出时间一致。第二步为返回给前端的时间格式和时区设定,保证前端页面显示时间和数据库一致

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值