Spring獲取日期時間差8小時問題解決


這個問題,惡心的一批。。無力吐槽

原文地址:https://blog.csdn.net/m0_38043362/article/details/78855196?utm_source=blogxgwz8

導致這個問題的原因,網上搜了一下,大概意思是:spring轉json的默認實現jackson中會根據時區去轉換時間,而jackson的默認時區跟國內是相差8小時的,所以這里得重新設置當前項目地所在時區。

1. application.yml 或者application.properties 文件中數據庫連接方式追加時區設置serverTimezone=GMT+8,這里轉換+號為 %2b 后使用

spring:
    datasource:
        # 主數據源
        datasource:
            driverClassName: com.mysql.jdbc.Driver
            jdbc-url: jdbc:mysql://localhost:3306/ga_qhfj_microffice?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2b8&useSSL=false
            username: root
            password: root

2.  application.properties 或  application.yml添加配置

#application.properties文件配置
spring.jackson.time-zone=GMT+8
 
------------------------------------
 
#application.yml文件配置
spring:
    jackson:
        time-zone: GMT+8

3.返回的實體類使用注解@JsonFormat

public class ArticleListVo {
    private Long articleId;
 
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")
    private Date createTime;
}

 

2019.6.10

這些方法都有些問題,本來我用的是第二種,結果發現有問題的時間戳正常了項目中其他地方的個別的時間戳又錯了,還是用最笨的辦法吧

在實體中多加兩個String屬性用來接收日期

在sql語句中將出問題的時間轉成字符串,在起個加的字段名稱的別名,在頁面中展示着兩個新加的屬性

sql中Data 轉 字符串 方法如下

DATE_FORMAT(table.start_time,'%Y-%m-%d %h:%i:%s') AS startTimenew

DATE_FORMAT(table.end_time,'%Y-%m-%d %h:%i:%s') AS endTimenew,

問題解決。。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM