工作随记:偶然一次排查问题时发现,bean接收到的参数比JSON格式传入的参数多了一个逗号,导致mysql执行更新操作失败。
猜想有一下可能:
1)在设置BEAN对应属性时,在后台插入了多余了逗号
2)postman传入参数时,多插入参数
3)JSON格式转bean的时候由于参数解析失败,造成多插入了参数。
经过单步调试,在BEAN属性的setter方法中,发现传入的参数前面即多余了逗号",",而postman传入参数时并没有添加入参数,
排除1,2之后,重点在JSON格式的解析上。
为了找出第三步的问题,经历一下排查步骤:
(1)、去掉传入参数值为空的参数,再次执行提交操作,发现传入的参数不再有多余的逗号,JSON和BEAN一一对应解析。
(2)、重新传入参数值为空的 参数,再次执行提交操作,发现传入的参数也不再有多余的逗号,前端JSON和BEAN一一对应解析。
(3)、在第一步取消参数值为空的参数时,整体传入的参数再减少,也就是有部分传入空的参数值有重复,在恢复传入空值的参数时(此时参数不再重复),JSON参数和BEAN属性能一一对应。
经过测试发现,如果同一个参数多次传入,BEAN的属性会同时接受,且两个值之间用逗号隔开,没有值的也会按照逗号隔开空值,比如:
//传入的JSON
{
"number":"1",
"number":"1"
"table":,
"table":
}
//BEAN接收到的值
number:1,1
table:"",""
所以在有重复的值情况下,JSON传引入了新的逗号"","",而且空值引号造成JSON解析错误,所以造成BEAN的属性接收错误。
问题解决:去掉重复参数后,问题得到解决。