后端 Date 时间 传到前端,相差8小时 | 您所在的位置:网站首页 › 框架不对 › 后端 Date 时间 传到前端,相差8小时 |
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不同),可能你配置的时区错了, 通过 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 实验室设备网 版权所有 |