這篇文章主要介紹了JsonFormat與@DateTimeFormat注解實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
背景:從數(shù)據(jù)庫獲取時間傳到前端進(jìn)行展示的時候,我們有時候可能無法得到一個滿意的時間格式的時間日期,在數(shù)據(jù)庫中顯示的是正確的時間格式,獲取出來卻變成了很丑的時間戳,@JsonFormat注解很好的解決了這個問題,我們通過使用@JsonFormat可以很好的解決:后臺到前臺時間格式保持一致的問題,其次,另一個問題是,我們在使用WEB服務(wù)的時,可能會需要用到,傳入時間給后臺,比如注冊新用戶需要填入出生日期等,這個時候前臺傳遞給后臺的時間格式同樣是不一致的,而我們的與之對應(yīng)的便有了另一個注解,@DataTimeFormat便很好的解決了這個問題,接下來記錄一下具體的@JsonFormat與DateTimeFormat的使用過程。
聲明:關(guān)于@JsonFormat的使用,一定要導(dǎo)入正確完整的包。
1.注解@JsonFormat
1.使用maven引入@JsonFormat所需要的jar包,我貼一下我這里的pom文件的依賴
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
<!--JsonFormat--> < dependency > < groupId >com.fasterxml.jackson.core</ groupId > < artifactId >jackson-annotations</ artifactId > < version >2.8.8</ version > </ dependency > < dependency > < groupId >com.fasterxml.jackson.core</ groupId > < artifactId >jackson-databind</ artifactId > < version >2.8.8</ version > </ dependency > < dependency > < groupId >org.codehaus.jackson</ groupId > < artifactId >jackson-mapper-asl</ artifactId > < version >1.9.13</ version > </ dependency > |
2.在你需要查詢出來的時間的數(shù)據(jù)庫字段對應(yīng)的實體類的屬性上添加@JsonFormat
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
import java.util.Date; import com.fasterxml.jackson.annotation.JsonFormat; public class TestClass { //設(shè)置時區(qū)為上海時區(qū),時間格式自己據(jù)需求定。 @JsonFormat (pattern= "yyyy-MM-dd" ,timezone = "GMT+8" ) private Date testTime; public Date gettestTime() { return testTime; } public void settestTime(Date testTimee) { this .testTime= testTime; } } |
這里解釋一下:@JsonFormat(pattern="yyyy-MM-dd",timezone = "GMT+8")
pattern:是你需要轉(zhuǎn)換的時間日期的格式
timezone:是時間設(shè)置為東八區(qū),避免時間在轉(zhuǎn)換中有誤差
提示:@JsonFormat注解可以在屬性的上方,同樣可以在屬性對應(yīng)的get方法上,兩種方式?jīng)]有區(qū)別
3.完成上面兩步之后,我們用對應(yīng)的實體類來接收數(shù)據(jù)庫查詢出來的結(jié)果時就完成了時間格式的轉(zhuǎn)換,再返回給前端時就是一個符合我們設(shè)置的時間格式了
2.注解@DateTimeFormat
1.@DateTimeFormat的使用和@jsonFormat差不多,首先需要引入是spring還有jodatime,spring我就不貼了
1
2
3
4
5
6
|
<!-- joda-time --> < dependency > < groupId >joda-time</ groupId > < artifactId >joda-time</ artifactId > < version >2.3</ version > </ dependency > |
2.在controller層我們使用spring mvc 表單自動封裝映射對象時,我們在對應(yīng)的接收前臺數(shù)據(jù)的對象的屬性上加@@DateTimeFormat
1
2
3
4
5
6
7
|
@DateTimeFormat (pattern = "yyyy-MM-dd" ) @JsonFormat (pattern = "yyyy-MM-dd HH:mm:ss" ,timezone= "GMT+8" ) private Date symstarttime; @DateTimeFormat (pattern = "yyyy-MM-dd" ) @JsonFormat (pattern = "yyyy-MM-dd HH:mm:ss" ,timezone= "GMT+8" ) private Date symendtime; |
我這里就只貼這兩個屬性了,這里我兩個注解都同時使用了,因為我既需要取數(shù)據(jù)到前臺,也需要前臺數(shù)據(jù)傳到后臺,都需要進(jìn)行時間格式的轉(zhuǎn)換,可以同時使用
3.通過上面兩個步驟之后,我們就可以獲取一個符合自定義格式的時間格式存儲到數(shù)據(jù)庫了
總結(jié):
注解@JsonFormat主要是后臺到前臺的時間格式的轉(zhuǎn)換
注解@DataFormAT主要是前后到后臺的時間格式的轉(zhuǎn)換
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://www.cnblogs.com/Struts-pring/p/10917977.html