欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 健康 > 美食 > 前后端分离项目中Spring Boot返回的时间与前端相差8个小时

前后端分离项目中Spring Boot返回的时间与前端相差8个小时

2024/10/25 2:31:25 来源:https://blog.csdn.net/weixin_44212870/article/details/139473159  浏览:    关键词:前后端分离项目中Spring Boot返回的时间与前端相差8个小时

概述

今天在做一个前后端分离项目时,发现从后端获取的时间与从数据库获取的时间相差八个小时,最终排查后发现由于Springboot使用本地时区导致,修改SpringBoot时区后解决

环境

  • MySQL8
  • SpringBoot

原因排查

发现从后端获取的数据总是比前端快八个小时

  • ajax返回数据
{"uid": 1,"username": "malong","password": "2","name": "mal","birthday": "2019-06-18T16:00:00.000+00:00","sex": "女","telephone": "010-1234567","email": "malong@163.com","status": "Y","code": "57fdfb86837c4888b12411b89eba00e1","isadmin": null,"deptId": 3,"deptName": null
}
  • 日志打印user对象
2024-06-05 15:18:15.717  WARN 6632 --- [nio-8080-exec-7] x.wrywebsite.controller.UserController   : User(uid=1, username=malong, password=2, name=mal, birthday=Wed Jun 19 00:00:00 CST 2019, sex=女, telephone=010-1234567, email=malong@163.com, status=Y, code=57fdfb86837c4888b12411b89eba00e1, isadmin=null, deptId=3, deptName=null)

发现后端时区为CST,前端为UTC

解决方案

修改Spring Boot时区,在项目启动前增加代码

@SpringBootApplication
@MapperScan("xyz.wrywebsite.dao")
public class UserServerApplication {public static void main(String[] args) {TimeZone.setDefault(TimeZone.getTimeZone("UTC"));SpringApplication.run(UserServerApplication.class, args);}}

修改后,再次启动,前后端date数据一致,问题解决

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com