SpringBoot开发接口接收日期类型的参数出现的问题
最近在项目上遇到一个AJAX表单提交然后插入数据这么一个简单的需求,但是表单中有多个日期类型的字段,后端用实体类接收,日期使用的是日期控件,总是报错:字符串和日期类型不能匹配的问题。不知道是我自己的问题还是公司框架的问题。搞了很长时间,特此记录。
经查阅资料解决方案如下:
1、直接将Date类型字段改为字符串类型
可以正常接收,但不推荐,日期类型就是日期类型,不要乱用,后面还要转来转去的麻烦。
2、设置局部转换(没解决我的问题)
在接口对应的Controller中加如下代码
@InitBinder
public void initBinder(WebDataBinder binder, WebRequest request) {
// 转换日期格式
DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
binder.registerCustomEditor(Date.class, new CustomDateEditor(dateFormat, true));
}
3、在日期类型字段上加注解(没解决我的问题)
@DateTimeFormat(pattern="yyyy-MM-dd") //页面写入数据库时格式化
@JSONField(format="yyyy-MM-dd") //数据库导出页面时json格式化
private Date date;
4、方案2 + 方案3一起用也没解决我的问题
5、解决我的问题的方案
在方案3的基础上
如果日期类型为空或null,就将此字段删除
// 去除对象内多余的空值key
function removeEmptyKey(obj) {
for (const key in obj) {
if (obj[key] === '' || obj[key] === null) {
delete obj[key]
}
}
return obj;
}
如果日期类型不为空,就先将其格式化。我试了直接不加时分秒的yyyy-MM-dd,但是还是报错,加上时分秒后完美解决报错问题(注:可能因为公司有封装东西在里面,所以会出现上述错误,大家按照自己的实际情况来采用解决方案,代码只能多试试,没准就解决了)
// 时间格式化
function dateFormat(fmt, date) {
let ret;
const opt = {
"y+": date.getFullYear().toString(), // 年
"M+": (date.getMonth() + 1).toString(), // 月
"d+": date.getDate().toString(), // 日
"h+": date.getHours().toString(), // 时
"m+": date.getMinutes().toString(), // 分
"s+": date.getSeconds().toString() // 秒
// 有其他格式化字符需求可以继续添加,必须转化成字符串
};
for (let k in opt) {
ret = new RegExp("(" + k + ")").exec(fmt);
if (ret) {
fmt = fmt.replace(ret[1], (ret[1].length == 1) ? (opt[k]) : (opt[k].padStart(ret[1].length, "0")))
}
}
return fmt;
}
dateFormat("yyyy-MM-dd hh:mm:ss", new Date())
—————————————— 华丽分割线 2023-12-28 补充更新 ——————————————————
突然发现,前端传时间字符串,后端用@JsonFormat直接就可以了
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone="GMT+8")