一、日期格式转换异常
Java报错Failed to convert property value of type ‘java.lang.String’ to required type 'java.util.Date
原因:因为前端传到后台的是字符串,而Java类属性的Date日期类型,此时需要@DateTimeFormat注解即可,但是注意用法:
@DateTimeFormat注解
①如果前端传过来是年月日
/**
* 生日
*/
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date eBirthday;
②如果前端传过来是年月日 时分秒
/**
* 生日
*/
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private Date eBirthday;
@JsonFormat注解
分Get和Post请求,两种不同的情况
Ⅰ、Get请求
Get方式传参 是 没有时区的影响的
@JsonFormat的作用: 返回给前端的时间是经过@JsonFormat格式化的时间。
@DateTimeFormat的作用: 前端需要按照@DateTimeForma的格式进行传参
示例:
Date 类型直接作为参数的情况
/**
* http://localhost:8080/test1?date=2019-01-18 11:11:11
*/
@RequestMapping(value = "/test1",method = RequestMethod.GET)
@ResponseBody
public void test1(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date date){
System.out.println(date);//Fri Jan 18 11:11:11 CST 2019
}
Date类型属性的实体类作为参数的情况
public class DateTestVO {
private Date finishDate;
}
@RequestMapping(value = "/test2",method = RequestMethod.GET)
@ResponseBody
public void test2(DateTestVO vo){
System.out.println(vo);
System.out.println(vo.getFinishDate());
return vo;
}
实体类中没有使用注解的时候
- 返回的是没有经过格式化的时间
使用的是默认格式的入参:
http://localhost:8080/test2?finishDate=2019/01/18 11:11:11
打印日志,正常:
DateTestVO{finishDate=Fri Jan 18 11:11:11 CST 2019}
Fri Jan 18 11:11:11 CST 2019
返回的是没有经过格式化的时间:
{
"finishDate": "2019-01-18T03:11:11.000+0000"
}
实体类中使用@JsonFormat注解的时候
@JsonFormat(pattern = “yyyy-MM-dd HH:mm:ss”,timezone=“GMT+8”)
使用的是默认格式的入参:
http://localhost:8080/test2?finishDate=2019/01/18 11:11:11
打印日志,正常:
DateTestVO{finishDate=Fri Jan 18 11:11:11 CST 2019}
Fri Jan 18 11:11:11 CST 2019
返回@JsonFormat格式的时间:
{
"finishDate": "2019-01-18 11:11:11"
}
实体类中使用@JsonFormat和@DateTimeFormat注解的时候
可以看到使用@DateTimeFormat注解后传入的参数类型为2019-01-18 11:11:11,而不是/
@JsonFormat(pattern = “yyyy-MM-dd HH:mm:ss”,timezone=“GMT+8”)
@DateTimeFormat(pattern = “yyyy-MM-dd HH:mm:ss”)
使用@DateTimeFormat格式的入参:
http://localhost:8080/test2?finishDate=2019-01-18 11:11:11
打印日志,正常:
DateTestVO{finishDate=Fri Jan 18 11:11:11 CST 2019}
Fri Jan 18 11:11:11 CST 2019
返回@JsonFormat格式的时间:
{
"finishDate": "2019-01-18 11:11:11"
}
Ⅱ、post请求
有时区的影响,如果不加注解打印的日志会显示时间多了八个小时,返回的结果不会多八个小时但没有格式化
@JsonFormat的作用:
1、后台接收后,没有时区的影响
2、返回给前端是格式化的时间
3、后端的入参按照@JsonFormat的格式传参(并没有使用@DateTimeFormat来格式化后端的入参)
二、日期格式比较冲突
*### Error querying database. Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
错误原因:因为实体类是Date 类型,当你的用字符串的形式判断该字段是否为空时,会抛出该错误
解决:只判断为空即可,可使用between..and来比较时间范围