三种时间差错问题:
- java下使用new date()获取的时间会和真实的本地时间相差8小时。
- 本地获取的时间没有错,存入数据库的时候时间相差8小时。
- 数据库时间没有错,获取到了后端,之后返回给前端相差8小时。
原因:
- new date()调用的是jvm时间,而jvm使用的时间默认是0时区的时间,即:和北京时间将会相差8小时。
- mybatis将本地的数据传入到mysql数据库服务器的时候,服务器会对数据进行检测,会把date类型的数据自动转换为mysql服务器所对应的时区,即0时区,所以会相差8小时。
- springboot中对加了@RestController或者@Controller+@ResponseBody注解的方法的返回值默认是Json格式,
- 所以,对date类型的数据,在返回浏览器端时,会被springboot默认的Jackson框架转换,而Jackson框架默认的时区GMT(相对于中国是少了8小时)。所以最终返回到前端结果是相差8小时
解决方案:
手动设置jvm时间:将时间改为第8时区的时间:
TimeZone.setDefault(TimeZone.getTimeZone("GMT+8"));
温馨提示:如果是springboot项目,可以面向切面加上这个,或者启动main类上加上如下代码:
@PostConstruct void started() { TimeZone.setDefault(TimeZone.getTimeZone("GMT+8")); }
注意:不要用下面方式,这个方式是错的,GMT-8最后获取的时区还是0时区的。网上很多的教程说的是下面的方式,亲测不行。
TimeZone tz = TimeZone.getTimeZone("ETC/GMT-8"); TimeZone.setDefault(tz);
在apprication.yml文件中配置一下数据库连接信息,url加上这么一句:
&serverTimezone=GMT%2b8
总结:都是时区问题
三个问题对应三种场景:
- 后台要存时间到数据库的时候:用方法2解决本地时间和数据库时间的问题;本质是sql的服务器时区是0时区导致。
- 后台要使用本地时间的时候,改变jvm的时区;本质是jvm的时区是0时区导致。
- 后台返回数据到前端的时候出现时区问题,用注解或者yml中配置json生成器解决转换格式的问题。本质是json的构造器用的时区是0时区导致。
到此这篇关于如何解决java获取时间相差8小时的问题的文章就介绍到这了,更多相关java获取时间本文来源gaodai#ma#com搞*!代#%^码$网!相差8小时内容请搜索搞代码以前的文章或继续浏览下面的相关文章希望大家以后多多支持搞代码!