后端 Date 时间 传到前端,相差8小时 您所在的位置:网站首页 框架不对 后端 Date 时间 传到前端,相差8小时

后端 Date 时间 传到前端,相差8小时

2024-07-01 10:46| 来源: 网络整理| 查看: 265

1.问题

后台时间正确,返回给前台的时间不正确,和后台差8个小时

后台打印的时间如下:

数据库存储时间如下:

接口返回给前台的时间如下:

相差8个小时

原因 spring中对于@RestController或者@Controller+@ResponseBody 注解的接口方法的返回值默认是Json格式, 所以当对于date类型的数据,在返回浏览器端是会被spring-boot 默认的Jackson框架转换,而Jackson框架默认的时区GMT(相对于中国是少了8小时)。

 

方案

1 如果你的项目是 spring-boot

在application.properties添加配置   配置spring的时区   这条语句能解决你时间少8个小时问题

spring.jackson.time-zone=GMT+8

在跟上一条时间戳配置

spring.jackson.date-format=yyyy-MM-dd HH:mm:ss

可以是Date时间格式化,一般这两条语句一起用

 

2 如果你的项目是 springMvc

在Spring MVC中经常需要返回json数据,对于日期类型数据可能会遇到返回格式化不对,返回的时间相差8小时等问题,今天我们一起来分享下在实际开发商过程中遇到的这两个问题。当然解决方法有很多种,本文中只选一种简单的方式。

日期返回数据没有格式化

在model中,使用注解方式格式化。示例代码如下:

@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss") public Date getCreatetime() { return createtime; } public void setCreatetime(Date createtime) { this.createtime = createtime; } 返回时间相差8个小时

这个主要是因为时区的问题,只要在Spring的配置文件中设置好时区就好了。代码如下:

NON_NULL   原因二

这个原因隐藏很深,当你发现你试过上面的方案后时间还是少的话,

请检查数据是从什么时候时间变少了,若从数据库查出来就少啦,

若你有用的数据库是mysql,

且mysql.jar是6.x版本的话(与5.x不同),可能你配置的时区错了,

通过

1552978601190

1552978601190

linux系统时区是UTC,而mysql使用的是系统时区。

方案

1  在  数据库的配置文件   jdbd url  加上

serverTimezone=Asia/Shanghai,

jdbc:mysql://localhost:3306/dcoj?serverTimezone=Asia/Shanghai

 

2、修改mysql数据库的my.cnf文件的[mysqld]字段,添加default-time-zone=+8:00

 

3、修改linux系统时区为Asia/Shanghai

mysql数据库运行在docker容器中,所以要修改mysql容器的时区为Asia/Shanghai。

进入mysql容器,链接文件,退出mysql容器,重启mysql(一气呵成)

docker exec -it mysql bash ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime exit docker restart mysql

 

原因

还有一种可能是自己的系统时间不对,这种是最小的可能性,网上讲到的不多,如果上面你都试啦还不对可以从这方面入手



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有