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();string转date的方法
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.verter.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_dTime,"%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;
该注解的作⽤是将数据库中的时间按指定的格式解析为字符串。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。