value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`)

报错信息:

Cannot deserialize value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`)

与之相似的还有:

JSON parse error: Cannot deserialize value of type `java.lang.Integer` from Boolean value

图片[1] - value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`) - MaxSSL

对比了我的测试用例前端的控制台实际传参,发现入参结构是一模一样,

图片[2] - value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`) - MaxSSL

但我这边测试用例可以正常新增写库,但前端却不能新增,报错Cannot deserialize value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`)

翻译过来意为:不能反序列化的值 类型java.lang.Long—->Object类型,表示代码试图反序列化时,遇到了异常,代码逻辑居然要求将Long类型强制反序列化回Object类型,所以报错了

这边看了下后端入参结构,是需要传一个VO

图片[3] - value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`) - MaxSSL
看一下VO内部,原来内部还套着一个VO,暂且叫它VO内

图片[4] - value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`) - MaxSSL

这里整理一下思路,按照前面测试用例的要求,

是需要传一个VO,除了基础的name等字段,还有一个属性,要一个集合 <VO内>

而这个内部的VO内却只需要传一个id,再瞅一眼id的类型,哦豁,Long类型,那说明异常就在这里了,可想而知,当前端的JSON类型入参到后端,后端将之反序列化为入参时,因为已经制定了入参类型,所以前面的name等字段都会对号入座,反序列化成为VO的属性,而前端的

"elementGroupVOList": [{"id": 12},{"id": 13}],

这堆东西,可就让JSON反序列化流懵逼了,这只丢给我一堆id,又没有指定发反序列化的目标类型是什么,那就给转成Object吧,然后一执行就出异常了,Long类型怎么转Object嘛,到这里,成功发生异常

到了这里,已经分析了异常的产生,再来想办法解决吧,以后端的思维来看,不是叫你把Long转为Object你就罢工嘛,你不知道要将id转成啥,那我给你指定一下,提供一个只有id的构造方法/函数,你去执行这个构造方法不就可以了

图片[5] - value of type `java.lang.Long` from Object value (token `JsonToken.START_OBJECT`) - MaxSSL

再重启项目,前端再执行新增,就正常了

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享