成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SpringBoot時間格式化的五種方法!

開發 前端
在我們日常工作中,時間格式化是一件經常遇到的事兒,所以本文我們就來盤點一下 Spring Boot 中時間格式化的幾種方法。

作者 | 王磊

來源 | Java中文社群(ID:javacn666)

轉載請聯系授權(微信ID:GG_Stone)

在我們日常工作中,時間格式化是一件經常遇到的事兒,所以本文我們就來盤點一下 Spring Boot 中時間格式化的幾種方法。

時間問題演示

為了方便演示,我寫了一個簡單 Spring Boot 項目,其中數據庫中包含了一張 userinfo 表,它的組成結構和數據信息如下:

項目目錄是這樣的:

UserController 實現代碼如下:

  1. @RestController 
  2. @RequestMapping("/user"
  3. publicclass UserController { 
  4.     @Resource 
  5.     private UserMapper userMapper; 
  6.  
  7.     @RequestMapping("/list"
  8.     public List<UserInfo> getList() { 
  9.         return userMapper.getList(); 
  10.     } 

UserMapper 實現代碼如下:

  1. @Mapper 
  2. publicinterface UserMapper { 
  3.     public List<UserInfo> getList(); 

UserInfo 實現代碼如下:

  1. @Data 
  2. publicclass UserInfo { 
  3.     privateint id; 
  4.     private String username; 
  5.     private Date createtime; 
  6.     private Date updatetime; 

UserMapper.xml 實現代碼如下:

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"
  3. <mapper namespace="com.example.demo.mapper.UserMapper"
  4.     <select id="getList" resultType="com.example.demo.model.UserInfo"
  5.         select * from userinfo 
  6.     </select
  7. </mapper> 

經過以上內容的編寫,我們就制作出了一個簡單的 Spring Boot 項目了。接下來,我們使用 PostMan 來模擬調用 UserController 接口,執行結果如下:

從上述結果可以看出,時間字段 createtime 和 updatetime 的顯示方式是很“凌亂”的,并不符合我們的閱讀習慣,也不能直接展示給前端的用戶使用,這時候,我們就需要對時間進行格式化處理了。

時間格式化的方法總共包含以下 5 種。

1.前端時間格式化

如果后端在公司中擁有絕對的話語權,或者是后端比較強勢的情況下,我們可以將時間格式化的這個“鍋”強行甩給前端來處理。

為了讓這個“鍋”甩的更平順一些(磊哥不做廚師都可惜了),咱們可以給前端工程師提供切實可行的時間格式化方法,實現代碼如下。

JS 版時間格式化

  1. function dateFormat(fmt, date) { 
  2.     let ret; 
  3.     const opt = { 
  4.         "Y+"date.getFullYear().toString(),        // 年 
  5.         "m+": (date.getMonth() + 1).toString(),     // 月 
  6.         "d+"date.getDate().toString(),            // 日 
  7.         "H+"date.getHours().toString(),           // 時 
  8.         "M+"date.getMinutes().toString(),         // 分 
  9.         "S+"date.getSeconds().toString()          // 秒 
  10.         // 有其他格式化字符需求可以繼續添加,必須轉化成字符串 
  11.     }; 
  12.     for (let k in opt) { 
  13.         ret = newRegExp("(" + k + ")").exec(fmt); 
  14.         if (ret) { 
  15.             fmt = fmt.replace(ret[1], (ret[1].length == 1) ? (opt[k]) : (opt[k].padStart(ret[1].length, "0"))) 
  16.         }; 
  17.     }; 
  18.     return fmt; 

方法調用:

  1. let date = newDate(); 
  2. dateFormat("YYYY-mm-dd HH:MM:SS"date); 
  3.  
  4. >>> 2021-07-2521:45:12 

2.SimpleDateFormat格式化

大多數情況下,我們還是需要自力更生,各掃門前雪的,這個時候我們后端程序員就需要發揮自己的特長了,我們提供的第 1 個時間格式化的方法是使用 SimpleDateFormat 來進行時間格式化,它也是 JDK 8 之前重要的時間格式化方法,它的核心實現代碼如下:

  1. // 定義時間格式化對象和定義格式化樣式 
  2. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
  3. // 格式化時間對象 
  4. String date = dateFormat.format(new Date()) 

樣式SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");// 格式化時間對象String date = dateFormat.format(new Date())

接下來我們使用 SimpleDateFormat 來實現一下本項目中的時間格式化,它的實現代碼如下:

  1. @RequestMapping("/list"
  2. public List<UserInfo> getList() { 
  3.     // 定義時間格式化對象 
  4.     SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
  5.     List<UserInfo> list = userMapper.getList(); 
  6.     // 循環執行時間格式化 
  7.     list.forEach(item -> { 
  8.         // 使用預留字段 ctime 接收 createtime 格式化的時間(Date->String) 
  9.         item.setCtime(dateFormat.format(item.getCreatetime())); 
  10.         item.setUtime(dateFormat.format(item.getUpdatetime())); 
  11.     }); 
  12.     return list; 

程序執行結果如下:

從上述結果可以看出,時間格式化沒有任何問題,以及到底我們預想的目的了。但細心的讀者會發現,為什么接口的返回字段咋變了呢?(之前的字段是 createtime 現在卻是 ctime...)

這是因為使用 #SimpleDateFormat.format 方法之后,它返回的是一個 String 類型的結果,而我們之前的 createtime 和 updatetime 字段都是 Date 類型的,因此它們是不能接收時間格式化得結果的。

所以此時我們就需要在實體類 UserInfo 新增兩個字符串類型的“時間”字段,再將之前 Data 類型的時間字段進行隱藏,最終實體類 UserInfo 的實現代碼如下:

  1. import com.fasterxml.jackson.annotation.JsonIgnore; 
  2. import lombok.Data; 
  3.  
  4. import java.util.Date
  5.  
  6. @Data 
  7. publicclass UserInfo { 
  8.     privateint id; 
  9.     private String username; 
  10.     @JsonIgnore// 輸出結果時隱藏此字段 
  11.     private Date createtime; 
  12.     // 時間格式化后的字段 
  13.     private String ctime; 
  14.     @JsonIgnore// 輸出結果時隱藏此字段 
  15.     private Date updatetime; 
  16.     // 時間格式化后的字段 
  17.     private String utime; 

我們可以使用 @JsonIgnore 注解將字段進行隱藏,隱藏之后的執行結果如下:

3.DateTimeFormatter格式化

JDK 8 之后,我們可以使用 DateTimeFormatter 來替代 SimpleDateFormat,因為 SimpleDateFormat 是非線程安全的,而 DateTimeFormatter 是線程安全的,所以如果是 JDK 8 以上的項目,盡量使用 DateTimeFormatter 來進行時間格式化。

DateTimeFormatter 格式化的代碼和 SimpleDateFormat 類似,具體實現如下:

  1. @RequestMapping("/list"
  2. public List<UserInfo> getList() { 
  3.     // 定義時間格式化對象 
  4.     DateTimeFormatter dateFormat = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); 
  5.     List<UserInfo> list = userMapper.getList(); 
  6.     // 循環執行時間格式化 
  7.     list.forEach(item -> { 
  8.         // 使用預留字段 ctime 接收 createtime 格式化的時間(Date->String) 
  9.         item.setCtime(dateFormat.format(item.getCreatetime())); 
  10.         item.setUtime(dateFormat.format(item.getUpdatetime())); 
  11.     }); 
  12.     return list; 

執行結果如下所示:

DateTimeFormatter 和 SimpleDateFormat 在使用上的區別是 DateTimeFormatter 是用來格式化 JDK 8 提供的時間類型的,如 LocalDateTime,而 SimpleDateFormat 是用來格式化 Date 類型的,所以我們需要對 UserInfoer 實體類做如下的修改:

  1. import com.fasterxml.jackson.annotation.JsonIgnore; 
  2. import lombok.Data; 
  3.  
  4. import java.time.LocalDateTime; 
  5.  
  6. @Data 
  7. publicclass UserInfo { 
  8.     privateint id; 
  9.     private String username; 
  10.     @JsonIgnore 
  11.     private LocalDateTime createtime; 
  12.     private String ctime; 
  13.     @JsonIgnore 
  14.     private LocalDateTime updatetime; 
  15.     private String utime; 

我們可以使用 LocalDateTime 來接收 MySQL 中的 datetime 類型。

4.全局時間格式化

以上兩種后端格式化的實現都有一個致命的缺點,它們在進行時間格式化的時候,都需要對核心業務類做一定的修改,這就相當為了解決一個問題,又引入了一個新的問題,那有沒有簡單一點、優雅一點的解決方案呢?

答案是:有的。我們可以不改任何代碼,只需要在配置文件中設置一下就可以實現時間格式化的功能了。

首先,我們找到 Spring Boot 的配置文件 application.properties(或 application.yml),只需要在 application.properties 配置文件中添加以下兩行配置:

  1. # 格式化全局時間字段 
  2. spring.jackson.date-format=yyyy-MM-dd HH:mm:ss 
  3. # 指定時間區域類型 
  4. spring.jackson.time-zone=GMT+8 

這樣設置之后,我們將原始的 UserInfo 和 UserController 進行還原。

UserInfo 實現代碼如下:

  1. import lombok.Data; 
  2. import java.util.Date
  3.  
  4. @Data 
  5. publicclass UserInfo { 
  6.     privateint id; 
  7.     private String username; 
  8.     private Date createtime; 
  9.     private Date updatetime; 

UserController 實現代碼:

  1. @RequestMapping("/list"
  2. public List<UserInfo> getList() { 
  3.     return userMapper.getList(); 

然后我們運行程序,看到的執行結果如下:

從以上結果和代碼可以看出,我們只需要在程序中簡單配置一下,就可以實現所有時間字段的格式化了。

實現原理分析

為什么在配置文件中設置一下,就可以實現所有時間字段的格式化了呢?

  1. # 格式化全局時間字段 
  2. spring.jackson.date-format=yyyy-MM-dd HH:mm:ss 
  3. # 指定時間區域類型 
  4. spring.jackson.time-zone=GMT+8 

這是因為 Controller 在返回數據時,會自動調用 Spring Boot 框架中內置的 JSON 框架 Jackson,對返回的數據進行統一的 JSON 格式化處理,在處理的過程中它會判斷配置文件中是否設置了“spring.jackson.date-format=yyyy-MM-dd HH:mm:ss”,如果設置了,那么 Jackson 框架在對時間類型的字段輸出時就會執行時間格式化的處理,這樣我們就通過配置來實現全局時間字段的格式化功能了。

為什么要指定時間區域類型“spring.jackson.time-zone=GMT+8”呢?

最現實的原因是,如果我們不指定時間區域類型,那么查詢出來的時間就會比預期的時間少 8 個小時,這因為我們(中國)所處的時間區域比世界時間少 8 個小時導致的,而當我們設置了時區之后,我們的時間查詢才會和預期時間保持一致。

GMT 是什么?

時間區域設置中的“GMT” 是什么意思?

Greenwich Mean Time (GMT) 格林尼治時間,也叫做世界時間。

格林尼治時間

格林尼治是英國倫敦南郊原皇家格林尼治天文臺所在地,地球本初子午線的標界處,世界計算時間和經度的起點。以其海事歷史、作為本初子午線的標準點、以及格林尼治時間以其命名而聞名于世。這里地勢險要,風景秀麗,兼具歷史和地方風情,也是倫敦在泰晤士河的東方門戶。

不光是天文學家使用格林尼治時間,就是在新聞報刊上也經常出現這個名詞。我們知道各地都有各地的地方時間。如果對國際上某一重大事情,用地方時間來記錄,就會感到復雜不便.而且將來日子一長容易搞錯。因此,天文學家就提出一個大家都能接受且又方便的記錄方法,那就是以格林尼治的地方時間為標準。

以本初子午線的平子夜起算的平太陽時。又稱格林尼治平時或格林尼治時間。各地的地方平時與世界時之差等于該地的地理經度。1960年以前曾作為基本時間計量系統被廣泛應用。由于地球自轉速率曾被認為是均勻的,因此在1960年以前,世界時被認為是一種均勻時。由于地球自轉速度變化的影響,它不是一種均勻的時間系統,它與原子時或力學時都沒有任何理論上的關系,只有通過觀測才能對它們進行比較。后來世界時先后被歷書時和原子時所取代,但在日常生活、天文導航、大地測量和宇宙飛行等方面仍屬必需;同時,世界時反映地球自轉速率的變化,是地球自轉參數之一,仍為天文學和地球物理學的基本資料。

5.部分時間格式化

某些場景下,我們不需要對全局的時間都進行統一的處理,這種情況我們可以使用注解的方式來實現部分時間字段的格式化。

我們需要在實體類 UserInfo 中添加 @JsonFormat 注解,這樣就可以實現時間的格式化功能了,實現代碼如下:

  1. import com.fasterxml.jackson.annotation.JsonFormat; 
  2. import lombok.Data; 
  3.  
  4. import java.util.Date
  5.  
  6. @Data 
  7. publicclass UserInfo { 
  8.     privateint id; 
  9.     private String username; 
  10.     // 對 createtime 字段進行格式化處理 
  11.     @JsonFormat(pattern = "yyyy-MM-dd hh:mm:ss", timezone = "GMT+8"
  12.     private Date createtime; 
  13.     private Date updatetime; 

修改完代碼之后,我們運行項目執行結果如下:

從上述結果可以看出,使用注解的方式也可以實現時間的格式化。它的實現原理和第 4 種時間格式化的實現原理類似,都是在返回數據之前,對相應的字段進行時間格式化的處理。

總結

本文我們介紹了 5 種時間格式化的實現方法,其中第 1 種為前端時間格式化的方法,后 4 種為后端格式化的方法,SimpleDateFormat 和 DateTimeFormatter 格式化的方法更適用普通的 Java 項目,其中 SimpleDateFormat 是非線程安全的,而 DateTimeFormatter 是線程安全的,但它們都不是 Spring Boot 項目中最優的時間格式化方案。

如果是 Spring Boot 的項目,推薦使用第 4 種全局時間格式化或第 5 種局部時間格式化的方式,這兩種實現方式都無需修改核心業務代碼,只需要簡單的配置一下,就可以完成時間的格式化功能了。

 

責任編輯:姜華 來源: Java中文社群
相關推薦

2022-09-05 08:06:36

SpringBoot時間格式化

2025-01-20 10:22:23

2024-06-07 09:06:36

2020-11-03 10:21:33

MySQL

2020-09-01 21:03:10

Springboot格式化方式

2022-12-29 08:46:15

IT采購投資

2022-10-17 15:59:40

Shell腳本終端

2023-10-30 17:41:29

機器人自動化

2022-12-07 11:24:51

首席信息官IT

2009-07-03 17:48:24

JSP頁面跳轉

2025-04-25 08:55:00

Pod運維

2011-07-27 09:41:52

虛擬化

2020-06-28 08:26:41

Python開發工具

2020-08-06 13:19:10

IBM多云管理

2020-12-03 14:40:10

云管理

2022-01-10 06:52:59

查詢MySQL字段

2011-04-21 10:08:34

2021-11-02 07:54:40

List分片Java

2022-06-17 10:44:53

數字化轉型CIOIT

2015-09-10 09:30:54

Java多線程同步
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久精品国产一区二区电影 | www.久久精品视频 | 欧美日韩在线一区二区三区 | 超碰激情| 国产精品久久久久久久久久三级 | 日韩欧美在线播放 | 亚洲 中文 欧美 日韩 在线观看 | 免费黄色片视频 | 国产精品久久久久久福利一牛影视 | 国产高清一区二区 | 国产精品久久久久久久久久久久冷 | 国产精品久久久久久福利一牛影视 | 午夜av在线| www.99热这里只有精品 | 日韩国产精品一区二区三区 | 国产日韩精品久久 | 中文字幕在线一区二区三区 | 免费a v网站 | 欧美国产精品久久久 | 久久久精品久 | 精品综合视频 | 久久人人网 | a级毛片基地 | 久久免费视频在线 | 97精品超碰一区二区三区 | 成人深夜福利 | 91精品国产91久久久久久吃药 | 精品久久久久久久 | 91 久久| 免费看91| 成人不卡一区二区 | 国产精品国产三级国产播12软件 | 9999精品视频 | www.av7788.com | 91精品国产99久久 | 欧美色综合天天久久综合精品 | 精品一二区 | 欧美理伦片在线播放 | 四虎永久在线精品免费一区二 | 国产精品久久久久久一区二区三区 | 久久一区精品 |