SpringBoot日期格式轉(zhuǎn)換之配置全局日期格式轉(zhuǎn)換器的實例詳解
1. SpringBoot設(shè)置后臺向前臺傳遞Date日期格式
在springboot應(yīng)用中,@RestController注解的json默認(rèn)序列化中,日期格式默認(rèn)為:2020-12-03T15:12:26.000+00:00類型的顯示。

在實際顯示中,我們需要對其轉(zhuǎn)換成我們需要的顯示格式。
1.1 方式1:配置文件修改
配置文件配置application.yml:
spring: # 配置日期格式化 jackson: date-format: yyyy-MM-dd HH:mm:ss #時間戳統(tǒng)一轉(zhuǎn)換為指定格式 time-zone: GMT+8 # 時區(qū)修改為東8區(qū)
application.properties配置方式
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss #時間戳統(tǒng)一轉(zhuǎn)換為指定格式 spring.jackson.time-zone=GMT+8 # 時區(qū)修改為東8區(qū)
【注意】這里需要修改時區(qū)time-zone:數(shù)據(jù)庫默認(rèn)時區(qū)是格林尼治的時間,如果不設(shè)置,會比實際時間少8個小時(北京時間)。
1.2 方式2:在javabean實體類上加注解
I. @JsonFormat注解
@JsonFormat注解用于屬性或方法上,將Date類型轉(zhuǎn)換為我們需要的類型顯示。
//在pattern上設(shè)置自己需要的格式 @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date createTime;
II. @DateTimeFormat注解
在需要進(jìn)行日期格式轉(zhuǎn)換的Date屬性上添加注解
@DateTimeFormat(pattern = "需要轉(zhuǎn)換的格式")
//注解將yyyy-MM-dd的形式轉(zhuǎn)換為Date數(shù)據(jù) @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date birthday;
III. @Temporal注解
通過@Temporal注解,實現(xiàn)日期格式轉(zhuǎn)換,它自帶屬性參數(shù),比如:
| @Temporal注解參數(shù) | 作用 |
|---|---|
| TemporalType.DATE | @Temporal(TemporalType.DATE),會得到y(tǒng)yyy-MM-dd格式的日期形式。 |
| TemporalType.TIME | @Temporal(TemporalType.TIME),會得到HH:MM:SS格式的時間形式。 |
| TemporalType.TIMESTAMP | @Temporal(TemporalType.TIMESTAMP),會得到y(tǒng)yyy-MM-dd hh:MM:ss格式的日期時間形式。 |
@Temporal(TemporalType.TIMESTAMP) private Date createTime;
2. SpringBoot配置全局日期格式轉(zhuǎn)換器
配置從頁面接收的String和json格式的日期轉(zhuǎn)換為Date類型。
2.1 配置String類型表單傳參轉(zhuǎn)Date的轉(zhuǎn)換器
import org.springframework.core.convert.converter.Converter;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
//Converter<S,T> S: 代表的是源,將要轉(zhuǎn)換的數(shù)據(jù)類型 T:目標(biāo)類型,將會轉(zhuǎn)成什么數(shù)據(jù)類型
@Component
public class GlobalFormDateConvert implements Converter<String, Date> {
//靜態(tài)初始化定義日期字符串參數(shù)列表(需要轉(zhuǎn)換的)
private static final List<String> paramList = new ArrayList<>();
//靜態(tài)初始化可能初夏你的日期格式
private static final String param1 = "yyyy-MM";
private static final String param2 = "yyyy-MM-dd";
private static final String param3 = "yyyy-MM-dd HH:mm";
private static final String param4 = "yyyy-MM-dd HH:mm:ss";
//靜態(tài)代碼塊,將日期參數(shù)加入到列表中
static {
paramList.add(param1);
paramList.add(param2);
paramList.add(param3);
paramList.add(param4);
}
//自定義函數(shù),將字符串轉(zhuǎn)Date 參1:傳入的日期字符串 參2:格式參數(shù)
public Date parseDate(String source, String format) {
System.out.println("parseDate轉(zhuǎn)換日期");
Date date = null;
try {
//日期格式轉(zhuǎn)換器
DateFormat dateFormat = new SimpleDateFormat(format);
date = dateFormat.parse(source);
} catch (Exception e) {
e.printStackTrace();
}
return date;
}
//convert轉(zhuǎn)換方法 ,s是將會傳遞過來的日期的字符串
@Override
public Date convert(String source) {
System.out.println("convert日期格式轉(zhuǎn)換器");
if(StringUtils.isEmpty(source)){
return null;
}
source = source.trim(); //去除首尾空格
DateFormat dateFormat = new SimpleDateFormat(param1);
//正則表達(dá)式判斷是哪一種格式參數(shù)
if (source.matches("^\\d{4}-\\d{1,2}$")) {
return parseDate(source, paramList.get(0));
} else if (source.matches("^\\d{4}-\\d{1,2}-\\d{1,2}$")) {
return parseDate(source, paramList.get(1));
} else if (source.matches("^\\d{4}-\\d{1,2}-\\d{1,2} {1}\\d{1,2}:\\d{1,2}$")) {
return parseDate(source, paramList.get(2));
} else if (source.matches("^\\d{4}-\\d{1,2}-\\d{1,2} {1}\\d{1,2}:\\d{1,2}:\\d{1,2}$")) {
return parseDate(source, paramList.get(3));
} else {
throw new IllegalArgumentException("還未定義該種字符串轉(zhuǎn)Date的日期轉(zhuǎn)換格式 --> 【日期格式】:" + source);
}
}
}
2.2 配置Json數(shù)據(jù)轉(zhuǎn)Date的全局日期轉(zhuǎn)換器
import java.text.FieldPosition;
import java.text.ParsePosition;
import java.text.SimpleDateFormat;
import java.util.Date;
import com.fasterxml.jackson.databind.util.StdDateFormat;
import org.springframework.util.StringUtils;
public class GlobalJsonDateConvert extends StdDateFormat {
//靜態(tài)初始化final,共享
public static final GlobalJsonDateConvert instance = new GlobalJsonDateConvert();
//覆蓋parse(String)這個方法即可實現(xiàn)
@Override
public Date parse(String dateStr, ParsePosition pos) {
return getDate(dateStr, pos);
}
@Override
public Date parse(String dateStr) {
ParsePosition pos = new ParsePosition(0);
return getDate(dateStr, pos);
}
private Date getDate(String dateStr, ParsePosition pos) {
System.out.println("json格式日期轉(zhuǎn)換");
SimpleDateFormat sdf = null;
if (StringUtils.isEmpty(dateStr)) {
return null;
} else if (dateStr.matches("^\\d{4}-\\d{1,2}$")) {
sdf = new SimpleDateFormat("yyyy-MM");
return sdf.parse(dateStr, pos);
} else if (dateStr.matches("^\\d{4}-\\d{1,2}-\\d{1,2}$")) {
sdf = new SimpleDateFormat("yyyy-MM-dd");
return sdf.parse(dateStr, pos);
} else if (dateStr.matches("^\\d{4}-\\d{1,2}-\\d{1,2} {1}\\d{1,2}:\\d{1,2}$")) {
sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm");
return sdf.parse(dateStr, pos);
} else if (dateStr.matches("^\\d{4}-\\d{1,2}-\\d{1,2} {1}\\d{1,2}:\\d{1,2}:\\d{1,2}$")) {
sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
return sdf.parse(dateStr, pos);
} else if (dateStr.length() == 23) {
sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
return sdf.parse(dateStr, pos);
}
return super.parse(dateStr, pos);
}
@Override
public StringBuffer format(Date date, StringBuffer toAppendTo, FieldPosition fieldPosition){
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
return sdf.format(date, toAppendTo, fieldPosition);
}
@Override
public GlobalJsonDateConvert clone() {
return new GlobalJsonDateConvert();
}
}
2.3 配置bean交給Spring管理
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.xgf.online_mall.convert.GlobalFormDateConvert;
import com.xgf.online_mall.convert.GlobalJsonDateConvert;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.support.ConversionServiceFactoryBean;
import org.springframework.core.convert.ConversionService;
import org.springframework.core.convert.converter.Converter;
import org.springframework.http.MediaType;
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
import java.util.ArrayList;
import java.util.List;
import java.util.HashSet;
import java.util.Set;
@Configuration
public class WebConfig {
//JSON格式 全局日期轉(zhuǎn)換器配置
@Bean
public MappingJackson2HttpMessageConverter getMappingJackson2HttpMessageConverter() {
MappingJackson2HttpMessageConverter mappingJackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter();
//設(shè)置日期格式
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setDateFormat(GlobalJsonDateConvert.instance);
objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
mappingJackson2HttpMessageConverter.setObjectMapper(objectMapper);
//設(shè)置中文編碼格式
List<MediaType> list = new ArrayList<MediaType>();
list.add(MediaType.APPLICATION_JSON_UTF8);
mappingJackson2HttpMessageConverter.setSupportedMediaTypes(list);
return mappingJackson2HttpMessageConverter;
}
//表單格式 全局日期轉(zhuǎn)換器
@Bean
@Autowired
public ConversionService getConversionService(GlobalFormDateConvert globalDateConvert){
ConversionServiceFactoryBean factoryBean = new ConversionServiceFactoryBean();
Set<Converter> converters = new HashSet<>();
converters.add(globalDateConvert);
factoryBean.setConverters(converters);
return factoryBean.getObject();
}
}
到此這篇關(guān)于SpringBoot日期格式轉(zhuǎn)換之配置全局日期格式轉(zhuǎn)換器的實例詳解的文章就介紹到這了,更多相關(guān)SpringBoot日期格式轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java排查進(jìn)程占用系統(tǒng)內(nèi)存高方法
這篇文章主要為大家介紹了java進(jìn)程占用系統(tǒng)內(nèi)存高排查方法,2023-06-06
springboot2.6.7集成springfox3.0.0的示例代碼
這篇文章主要介紹了springboot2.6.7集成springfox3.0.0的示例代碼,本文通過示例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-04-04
LocalDateTime日期時間格式中間多了一個T的問題及解決
這篇文章主要介紹了LocalDateTime日期時間格式中間多了一個T的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
Java解決線程的不安全問題之volatile關(guān)鍵字詳解
這篇文章主要介紹了Java解決線程的不安全問題之volatile關(guān)鍵字詳解,可見性指一個線程對共享變量值的修改,能夠及時地被其他線程看到,而 volatile 關(guān)鍵字就保證內(nèi)存的可見性,需要的朋友可以參考下2023-08-08

