一问题
Caused by: com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `java.lang.String` out of START_OBJECT token
at [Source: (String)"{"code":500,"data":null,"errorInfo":{"code":500,"data":null,"date":1592810896632,"msg":"XX失败"},"msg":"XX失败"}"; line: 1, column: 37] (through reference chain: com..XX..["errorInfo"])
at com.fasterxml.jackson.databind.exc.MismatchedInputException.from(MismatchedInputException.java:63)
at com.fasterxml.jackson.databind.DeserializationContext.reportInputMismatch(DeserializationContext.java:1343)
at com.fasterxml.jackson.databind.DeserializationContext.handleUnexpectedToken(DeserializationContext.java:1139)
at com.fasterxml.jackson.databind.DeserializationContext.handleUnexpectedToken(DeserializationContext.java:1093)
at com.fasterxml.jackson.databind.deser.std.StringDeserializer.deserialize(StringDeserializer.java:63)
at com.fasterxml.jackson.databind.deser.std.StringDeserializer.deserialize(StringDeserializer.java:10)
at com.fasterxml.jackson.databind.deser.impl.MethodProperty.deserializeAndSet(MethodProperty.java:129)
at com.fasterxml.jackson.databind.deser.BeanDeserializer.vanillaDeserialize(BeanDeserializer.java:288)
at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:151)
at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:4013)
at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:3004)
at com.benmu.api.json.JsonUtil.of(JsonUtil.java:112)
... 78 common frames omitted
我再调用三方接口的时候,返回的json要解析成bean对象XXresp,正常的情况下,errorInfo为null 不报错。
异常情况下这个异常信息解析失败。这个沿用了工程中的jackson方式解析JSON:
XXresp 对应的字段为String类型。
二 解决:
这个报错跟哪个缺少无参构造器导致无法实例化的报错还是有明显区别的。
就是类型不对,返回的是JSON,String处理不了。
方法1
加个类,属性呢跟errorInfo 对应上。
方法2:
如果确定没啥用途,解析用不到,可以直接删除掉。
亲测两种方式都好使。