javascript
data spring 指定时区_SpringBoot 统一时区的方案
系統(tǒng)采用多時區(qū)設(shè)計的時候,往往我們需要統(tǒng)一時區(qū),需要統(tǒng)一的地方如下:
服務(wù)器(Tomcat服務(wù))
數(shù)據(jù)庫(JPA + Hibernate)
前端數(shù)據(jù)(前端采用Vuejs)
思路為:
將數(shù)據(jù)庫和服務(wù)器的時間都采用標(biāo)準(zhǔn)時區(qū)UTC存儲處理。前端拿到標(biāo)準(zhǔn)時區(qū)的數(shù)據(jù),統(tǒng)一根據(jù)用戶所在時區(qū)進(jìn)行轉(zhuǎn)換。這樣保證了后端數(shù)據(jù)時區(qū)的一致性,前端根據(jù)實際情況進(jìn)行渲染。
保證服務(wù)器時區(qū)為UTC
服務(wù)啟動的時候,將當(dāng)前時區(qū)設(shè)置為UTC,代碼如下:
@SpringBootApplication
public class Application {
@PostConstruct
void started() {
TimeZone.setDefault(TimeZone.getTimeZone("UTC"));
}
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
這樣就保證了Java程序的時區(qū)為UTC。
保證數(shù)據(jù)庫時區(qū)為UTC
Hibernate支持設(shè)置時區(qū),在Springboot中增加配置如下:
spring.jpa.properties.hibernate.jdbc.time_zone = UTC
如果是MySQL數(shù)據(jù)庫,連接池鏈接后面增加配置如下:
?serverTimezone=TimeZone&useLegacyDatetimeCode=false
如:
spring.datasource.url=jdbc:mysql://localhost:3306/db?useUnicode=true&characterEncoding=utf-8&useLegacyDatetimeCode=false&serverTimezone=UTC
其中useLegacyDatetimeCode參數(shù)默認(rèn)是true,我們需要手動設(shè)置為false,否則無效。
總結(jié)
以上是生活随笔為你收集整理的data spring 指定时区_SpringBoot 统一时区的方案的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 暖通lisp快捷键_CAD 快捷键一览
- 下一篇: R语言chorolayer_R语言空间可