JAVA BEAN在controller层接收JSON数据中多了逗号问题的排查

工作随记:偶然一次排查问题时发现,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的属性接收错误。

问题解决:去掉重复参数后,问题得到解决。

猜你喜欢

转载自blog.csdn.net/jinger_000/article/details/85076530