前端向后端传递时间,数据库中的时间提交的时间多8个小时

原因一:

spring中对于@RestController或者@Controller+@ResponseBody
注解的接口方法的返回值默认是Json格式,
所以当对于date类型的数据,在返回浏览器端是会被spring-boot
默认的Jackson框架转换,而Jackson框架默认的时区GMT(相对于中国是少了8小时)。
解决方案:

  • 1 如果项目是 spring-boot
    在application.properties添加配置 配置spring的时区 (yml同理,只是格式不同)
spring.jackson.time-zone=GMT+8

同时对时间格式进行配置(根据需求是否对格式进行特定要求)

spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
  • 2.如果项目是 springMvc
    (1)日期返回数据没有格式化
    在model中,使用注解方式格式化。示例代码如下:
@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss")
    public Date getCreatetime() {
        return createtime;
    }
 
    public void setCreatetime(Date createtime) {
        this.createtime = createtime;
    }

(2)返回时间相差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>

原因二:

还有一个原因就是数据的时区和Linux系统的时区存在差异。
查看数据库时区:

show variables like "%time_zone%";

前端向后端传递时间,数据库中的时间提交的时间多8个小时_第1张图片
这个是正确的时区。如果为空,或者不是正确的时区,则需要修改。
linux系统的时间查询:

//查看当前时区
date -R

Linux时间设置(系统时间和硬件时间)
解决方案:

  • 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

你可能感兴趣的:(#,Spring,boot)