SpringBoot全域性時間轉換器
阿新 • • 發佈:2020-12-29
SpringBoot全域性時間轉換器
日常開發中,接收時間型別引數處處可見,但是針對不同的介面。往往需要的時間型別不一致
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")需要每個屬性上都要增加,大大增加工作量
可通過實現Converter介面,進行全域性時間轉換
全域性時間轉換程式碼
import org.springframework.core.convert.converter.Converter; import org.springframework.stereotype.Component; import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * 非requestbody方式接收date引數轉換器 * requestbody形式,採用json序列化進行配置格式 * 本轉換器只接收-為間隔。統一返回給前端的也以-為間隔 * 若新增型別,可增加formats與正則匹配進行轉換 */ @Component public class DateConverterConfig implements Converter<String, Date> { private static final List<String> formarts = new ArrayList<>(4); /** * 支援的格式 * 既然已經使用了轉換器,就不使用yyyy/MM等形式了。 * 全域性均使用yyyy-MM形式 */ static { formarts.add("yyyy-MM"); formarts.add("yyyy-MM-dd"); formarts.add("yyyy-MM-dd HH:mm"); formarts.add("yyyy-MM-dd HH:mm:ss"); } @Override public Date convert(String source) { String value = source.trim(); if ("".equals(value)) { return null; } if (source.matches("^\\d{4}-\\d{1,2}$")) { return parseDate(source, formarts.get(0)); } else if (source.matches("^\\d{4}-\\d{1,2}-\\d{1,2}$")) { return parseDate(source, formarts.get(1)); } else if (source.matches("^\\d{4}-\\d{1,2}-\\d{1,2} {1}\\d{1,2}:\\d{1,2}$")) { return parseDate(source, formarts.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, formarts.get(3)); } else { throw new IllegalArgumentException("Invalid boolean value '" + source + "'"); } } /** * 格式化日期 * * @param dateStr String 字元型日期 * @param format String 格式 * @return Date 日期 */ public Date parseDate(String dateStr, String format) { Date date = null; try { DateFormat dateFormat = new SimpleDateFormat(format); date = dateFormat.parse(dateStr); } catch (Exception e) { } return date; } }