如何解决java获取时间相差8⼩时的问题
⽬录
三种时间差错问题:
原因:
解决⽅案:
总结:都是时区问题
三种时间差错问题:
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.TimeZone("GMT+8"));
温馨提⽰:如果是springboot项⽬,可以⾯向切⾯加上这个,或者启动main类上加上如下代码:
@PostConstruct
void started() {
TimeZone.TimeZone("GMT+8"));
}
注意:不要⽤下⾯⽅式,这个⽅式是错的,GMT-8最后获取的时区还是0时区的。⽹上很多的教程说的是下⾯的⽅式,亲测不⾏。
TimeZone tz = TimeZone("ETC/GMT-8");
TimeZone.setDefault(tz);
在l⽂件中配置⼀下数据库连接信息,url加上这么⼀句:
&serverTimezone=GMT%2b8
可以解决存⼊数据库的时间肯定是对的,本地获取的时间则未必是北京时间。将spring的json构造器的时区改正即可,在l⽂件中添加:
或者可以使⽤注解,在entity实体类的date数据上添加注解,那么数据库传回的data数据要转换为json格式的时候就是北京时间了,再次传回到前端的时候,也不会出现时区问题。
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
private Date lastTime;
不过,指的注意的是:这样做,如果你的jvm时间依然是后台0时区的,那么后台要⽤时间执⾏逻辑的时候,就要注意了,时间依然相差8⼩时,还是建议⽤第⼀⽅法,直接整个jvm改为北京的8时区。
总结:都是时区问题
三个问题对应三种场景:
后台要存时间到数据库的时候:⽤⽅法2解决本地时间和数据库时间的问题;本质是sql的服务器时区是0时区导致。
后台要使⽤本地时间的时候,改变jvm的时区;本质是jvm的时区是0时区导致。
后台返回数据到前端的时候出现时区问题,⽤注解或者yml中配置json⽣成器解决转换格式的问题。本质是json的构造器⽤的时区是0时区导致。
到此这篇关于如何解决java获取时间相差8⼩时的问题的⽂章就介绍到这了,更多相关java获取时间相差8⼩时内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!
>java时间日期格式转换

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。