后端 Date 时间 传到前端,相差8小时

1.问题

后台时间正确,返回给前台的时间不正确,和后台差8个小时
后台打印的时间如下:
在这里插入图片描述
数据库存储时间如下:
在这里插入图片描述
接口返回给前台的时间如下:
后端 Date 时间 传到前端,相差8小时_第1张图片
相差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: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不同),可能你配置的时区错了
后端 Date 时间 传到前端,相差8小时_第2张图片
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

后端 Date 时间 传到前端,相差8小时_第3张图片

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

你可能感兴趣的:(java)