ssm中的日期转换

1. 将表单传入的日期设置为指定格式

1.1 自定义类(在需要的时候调用方法进行转换即可)

private Date getDate(String pubstr) {
try {
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
return df.parse(pubstr);
} catch (ParseException e) {
e.printStackTrace();
return new Date();
}
}
book.setPubdate(getDate(pubstr));

注意:pubstr是一个以字符串显示的时间。

 

注意:如果是要返回一个实体类型,可以写一个包装类,将实体类中的Date设置为指定的格式,并返回json数据。

1.2 自定义类加注解 

1.2.1   

创建一个日期转换类实现Converter接口,将String类型的日期转换成java中的Date类型,如果数据库中的字段设置为date,则SimpleDateFormat中设置格式为(yyyy-MM-dd),如果为datetime,则SimpleDateFormat中设置格式为(yyyy-MM-dd HH:mm:ss)。

public class CustomDateConverter implements Converter<String, Date>{
   @Override
   public Date convert(String source) {
      // 将日期串转换成日期格式(格式是yyyy-MM-dd)
      SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
      try {
         //返回上述格式的Date类型对象
         return simpleDateFormat.parse(source);
      } catch (ParseException e) {
         // TODO Auto-generated catch block
         e.printStackTrace();
      }
      return null;
   }
}

配置:

将自定义的转换类在springmvc中配置,并且在mvc:annotation-driven添加conversion-service属性,值为conversionService。

<!-- 自定义参数绑定 -->
   <bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
      <!-- 转换器 -->
      <property name="converters">
      <!-- 日期类型的转换 -->
         <bean class="cn.haohan.ssm.converter.CustomDateConverter"></bean>
      </property>
   </bean>
 
<mvc:annotation-driven conversion-service="conversionService">
   </mvc:annotation-driven>

1.3 前端传递的是json数据,直接实体类的字段上使用注解

@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birth;

该注解的作用是将 前端传递的时间数据(实际上就是字符串形式),按照给定的格式解析为数据库中表对应的Date类型

2. 将从数据库中查询出来的日期以特定格式显示到前端

2.1 数据库层

select 

DATE_FORMAT(t.startTime,"%Y-%m-%d %H:%i") AS startTime,

DATE_FORMAT(t.endTime,"%Y-%m-%d %H:%i") AS endTime

from table

格式:

format字符串:
%M 月名字(January……December)
%W 星期名字(Sunday……Saturday)
%D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)
%Y 年, 数字, 4%y 年, 数字, 2%a 缩写的星期名字(Sun……Sat)
%d 月份中的天数, 数字(00……31)
%e 月份中的天数, 数字(0……31)
%m 月, 数字(01……12)
%c 月, 数字(1……12)
%b 缩写的月份名字(Jan……Dec)
%j 一年中的天数(001……366)
%H 小时(00……23)
%k 小时(0……23)
%h 小时(01……12)
%I 小时(01……12)
%l 小时(1……12)
%i 分钟, 数字(00……59)
%r 时间,12 小时(hh:mm:ss [AP]M)
%T 时间,24 小时(hh:mm:ss)
%S 秒(00……59)
%s 秒(00……59)
%p AM或PM
%w 一个星期中的天数(0=Sunday ……6=Saturday )
%U 星期(0……52), 这里星期天是星期的第一天
%u 星期(0……52), 这里星期一是星期的第一天
%% 一个文字“%

 

2.2 在程序中控制

Date date =new Date();
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String dat=sdf.format(date);

2.3  在实体类的字段上使用注解  


@JsonFormat(pattern = "yyyy-MM-dd") 
private Date birth;

该注解的作用是将数据库中的时间按指定的格式解析为字符串。

 

 

posted @ 2021-09-26 17:27  木有呂朋友  阅读(301)  评论(0编辑  收藏  举报