经过上一次后端的开发后,一共总结了后端在开发过程中会有三个地方涉及到时间与时区的设置,分别是:

  • 存入数据库数据时的时间
  • 日志打印的时间
  • Jackson在进行数据格式转换时的时间

       这里我们所用的数据库为 Mysql,字段中的时间类型为 datetime,java实体类中所使用的时间类型为 Date
       首先是存入数据库数据时的时间,这个一般存在的问题是时区,我们只需要在url后加上时区的参数即可(serverTimezone=Asia/Shanghai):

url: jdbc:mysql://localhost:3306/xxxx?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&autoReconnect=true&serverTimezone=Asia/Shanghai

       关于jackson时间的格式,这个一般给前端进行展示的,所以格式一般又前端来决定,这里我们需要在配置文件application里进行修改:

spring:
 jackson:
   date-format: yyyy-MM-dd HH:mm:ss     #和前端沟通好
   time-zone: Asia/Shanghai

       我们也可以单独在某一个实体类的时间类型的字段上加上@JsonFomat来进行时间格式化。
       最后是日志的输出时间,起初我是在部署了项目之后,在linux端看日志的时候发现了时间不对的情况,经过多次排查发现是日志配置文件 logback.xml 的问题,我们需要在< pattern>中加上时区的设置,即可保证日志时间正确:

<pattern>[%level] %d{yyyy-MM-dd HH:mm:ss.SSS,Asia/Shanghai} %X{logId} %c.java - %msg%n</pattern>

更多推荐