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的配置文件中设置好时区就好了。代码如下:
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