在日常开发中,涉及到日期时间类型Date和常用的注解@DateTimeFormat和@JsonFormat
java.util.Date;
org.springframework.format.annotation.DateTimeFormat;
com.fasterxml.jackson.annotation.JsonFormat;
一 Date类型字段不使用注解
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Emp {private Date date;
}@RestController
public class FrontController {@PostMapping("/one")public Emp testOne(Emp emp) {System.out.println("接收到的入参是: " + emp);return emp;}@PostMapping("/two")public Emp testTwo(@RequestBody Emp emp) {System.out.println("接收到的入参是: " + emp);return emp;}
}
如果是Params传参,无论参数用什么样的日期时间格式,都会报400错误;
如果是json格式传参,前端传参格式只能是yyyy-MM-dd格式,其他格式都会报400错误;
前端使用json格式,日期时间类型格式是yyyy-MM-dd,前端默认使用世界时间传递,会自动补齐时分秒00时00分00秒,Date数据类型又会将时间转换为当前时区的时间:
前端请求时间和后端代码处理时间不一致,Java代码处理的日期时间是东八区时间;
前端请求时间和后端响应时间一致,响应前端的时候又转换时间为世界时IOS格式;
二 使用注解@DateTimeFormat
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Emp {@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")private Date date;
}
如果是Params传参,前端传参格式只能是@DateTimeFormat注解定义的格式,否则报400错误;
如果是json格式传参,前端传参格式只能是yyyy-MM-dd格式,其他格式都会报400错误;
前端使用Params传递参数,日期时间格式和@DateTimeFormat注解定义的格式保持一致:
前端请求时间和后端代码处理时间一致;
前端请求时间和后端响应时间不一致;
前端使用json格式传参,前端传参格式只能是yyyy-MM-dd格式,其他格式都会报400错误,作用效果和不使用注解一样:
前端请求时间和后端代码处理时间不一致,Java代码处理的日期时间是东八区时间;
前端请求时间和后端响应时间一致,响应前端的时候又转换时间为世界时IOS格式;
小结:@DateTimeFormat注解的日期时间类型,前端主要是在Params中传参(即url传参),在前端向后端传日期时间类型数据的时候进行格式化,注解可以用在Date类型字段上和set方法上,或是方法入参上。
三 使用注解@JsonFormat
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Emp {@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")private Date date;
}
如果是Params传参,无论参数用什么样的日期时间格式,都会报400错误;
如果是json格式传参,前端传参格式只能是@JsonFormat注解定义的格式,其他格式都会报400错误;
前端使用json传递参数,日期时间格式和@JsonFormat注解定义的格式保持一致:
前端请求时间和后端代码处理时间一致;
前端请求时间和后端响应时间一致;
小结:@JsonFormat注解的日期时间类型,前端只能使用json格式传参,注解可以用在Date类型字段上和set方法上,或是方法入参上。
四 总结
在后台处理日期时间类型时,既要保证后台接收到的日期时间数据格式正确,又要保证后台响应的日期时间数据格式正确:
@DateTimeFormat注解,可以保证前端Params传参时,后台接收处理的日期时间数据格式正确;
@JsonFormat注解,可以保证前端json传参时,后台接收处理的日期时间数据格式正确;
@JsonFormat注解,还可以保证后台响应的日期时间数据格式正确;
所以在日常开发中,@DateTimeFormat和@JsonFormat这两个注解常配合使用;