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;
该注解的作用是将数据库中的时间按指定的格式解析为字符串。