JsonFormat與@DateTimeFormat注解實例解析
這篇文章主要介紹了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文件的依賴
<!--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
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我就不貼了
<!-- 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
@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í)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于mybatis-plus邏輯刪除自動填充更新時間的問題
mybatis-plus是對mybatis的增強(qiáng),mybatis-plus更像是面向?qū)ο缶幊?,?shù)據(jù)庫基本CRUD的操作可以不用手動編寫SQL語句,大大提高了開發(fā)的效率,這篇文章主要介紹了mybatis-plus邏輯刪除自動填充更新時間問題,需要的朋友可以參考下2022-07-07
SpringBoot獲取客戶端的IP地址的實現(xiàn)示例
在Web應(yīng)用程序中,獲取客戶端的IP地址是一項非常常見的需求,本文主要介紹了SpringBoot獲取客戶端的IP地址的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下2023-09-09
MyBatis在Mapper中傳遞多個參數(shù)的四種方法詳解
這篇文章主要介紹了MyBatis在Mapper中傳遞多個參數(shù)的四種方法,文章通過代碼示例介紹的非常詳細(xì),具有一定的參考價值,,需要的朋友可以參考下2023-09-09
SpringBoot解決Required?String?parameter?xxx?is?not?prese
這篇文章主要介紹了SpringBoot解決Required?String?parameter?xxx?is?not?present問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01

