@datetimeformat注解使用

1. 准备

定义一个pojo,它有一个 java.util.Date 类型的属性 date。


   
   
   
   
  1. import java.util. Date;
  2. public class DateVo {
  3. private Date date;
  4. public void setDate( Date date){
  5. this. date = date;
  6. }
  7. public Date getDate(){
  8. return date;
  9. }
  10. }

定义一个Controller


   
   
   
   
  1. @RestController
  2. @RequestMapping("/date/")
  3. public class DateController {
  4. @RequestMapping("test")
  5. public DateVo getDate(DateVo vo){
  6. System. out.println( "date1:"+vo.getDate());
  7. SimpleDateFormat sdf = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss");
  8. String date = sdf.format(vo.getDate());
  9. System. out.println( "date2:"+date);
  10. DateVo vo2 = new DateVo();
  11. vo2.setDate(new Date());
  12. return vo2;
  13. }
  14. }

访问 /date/test ,并传入参数:2018-08-02 22:05:55

发现并不能访问成功,会抛出异常:

因为传入的参数是 String 类型的,而用来接收参数的 DateVo 的 date 属性是 java.util.Date 类型的,类型无法转换。

2. 入参格式化

这时,就可以使用 Spring 的 @DateTimeFormat 注解格式化参数,来解决上述问题。

改造 DateVo:


   
   
   
   
  1. public class DateVo {
  2. @DateTimeFormat(pattern= "yyyy-MM-dd HH:mm:ss")
  3. private Date date;
  4. public void setDate( Date date){
  5. this. date = date;
  6. }
  7. public Date getDate(){
  8. return date;
  9. }
  10. }

再像上面一样访问 /date/test ,并传入参数:2018-08-02 22:05:55,将在控制台上打印:

date1:Thu Aug 02 22:05:55 CST 2018

date2:2018-08-02 22:05:55

可以看到,加入 @DateTimeFormat 注解后参数可以被接收到了,但日期时间的格式还是需要自己再手动转换一下。

因为 @DateTimeFormat 注解的 pattern 属性值指定的日期时间格式并不是将要转换成的日期格式,这个指定的格式是和传入的参数对应的,假如注解为:

@DateTimeFormat(pattern="yyyy/MM/dd HH:mm:ss")

则传入的参数应该是这样的:

2018/08/02 22:05:55

否则会抛出异常。

3. 出参格式化

在上述示例中,调用接口的返回结果为:

"date": "2018-08-01T14:25:31.296+0000"

这个格式并不是我们想要的,那么如何将其进行格式化?这时就需要用到 jackson 的 @JsonFormat 注解。

改造 DateVo:


   
   
   
   
  1. public class DateVo {
  2. @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
  3. @JsonFormat(
  4. pattern = "yyyy-MM-dd HH:mm:ss"
  5. )
  6. private Date date;
  7. public void setDate(Date date){
  8. this.date = date;
  9. }
  10. public Date getDate(){
  11. return date;
  12. }
  13. }

继续访问 /date/test ,并传入参数:2018-08-02 22:05:55,可以看到接口返回的结果为:

"date": "2018-08-01 14:32:57"

虽然时间格式正确了,但实际上当前时间是 “2018-08-01 22:32:57” ,早了8个小时。因为,jackson在序列化时间时是按照国际标准时间GMT进行格式化的,而在国内默认时区使用的是CST时区,两者相差8小时。

所以,@JsonFormat 注解还要再加一个属性:


   
   
   
   
  1. @JsonFormat(
  2. pattern = "yyyy-MM-dd HH:mm:ss"
  3. timezone = "GMT+8"
  4. )
  5. private Date date;

这样,结果就正确了。

因为 @JsonFormat 注解不是 Spring 自带的注解,所以使用该注解前需要添加 jackson 相关的依赖包。当然,如果是 SpringBoot 项目就不需要自己手动添加依赖了,因为在 spring-boot-start-web 下已经包含了 jackson 相关依赖。

你可能感兴趣的:(Java)