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的配置文件中设置好时区就好了。代码如下:
<mvc:annotation-driven>
<!-- 处理请求时返回json字符串的中文乱码问题 -->
<mvc:message-converters register-defaults="true">
<bean class="org.springframework.http.converter.StringHttpMessageConverter">
<constructor-arg value="UTF-8" />
</bean>
<!--处理时区问题-->
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<property name="objectMapper">
<bean class="com.fasterxml.jackson.databind.ObjectMapper">
<!-- 处理responseBody 里面日期类型 -->
<property name="dateFormat">
<bean class="java.text.SimpleDateFormat">
<constructor-arg type="java.lang.String" value="yyyy-MM-dd HH:mm:ss" />
</bean>
</property>
<!-- 时区指定 -->
<property name="timeZone" value="GMT+8" />
<!-- 为null字段时不显示 -->
<property name="serializationInclusion">
<value type="com.fasterxml.jackson.annotation.JsonInclude.Include">NON_NULL</value>
</property>
</bean>
</property>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
原因二
这个原因隐藏很深,当你发现你试过上面的方案后时间还是少的话,
请检查数据是从什么时候时间变少了,若从数据库查出来就少啦,
若你有用的数据库是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
原因
还有一种可能是自己的系统时间不对,这种是最小的可能性,网上讲到的不多,如果上面你都试啦还不对可以从这方面入手