Caused by: com.fasterxml.jackson.databind.JsonMappingException: No serializer found for class java.io.ByteArrayInputStream and no properties discovered to create BeanSerializer (to avoid exception, disable SerializationFeature.FAIL_ON_EMPTY_BEANS) (through reference chain: com.alibaba.fastjson.JSONObject["file"]->org.springframework.core.io.ByteArrayResource["inputStream"]) at com.fasterxml.jackson.databind.JsonMappingException.from(JsonMappingException.java:284) at com.fasterxml.jackson.databind.SerializerProvider.mappingException(SerializerProvider.java:1110) at com.fasterxml.jackson.databind.SerializerProvider.reportMappingProblem(SerializerProvider.java:1135) at com.fasterxml.jackson.databind.ser.impl.UnknownSerializer.failForEmpty(UnknownSerializer.java:69) at com.fasterxml.jackson.databind.ser.impl.UnknownSerializer.serialize(UnknownSerializer.java:32) at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:704) at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:689) at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:155) at com.fasterxml.jackson.databind.ser.std.MapSerializer.serializeFields(MapSerializer.java:633) at com.fasterxml.jackson.databind.ser.std.MapSerializer.serialize(MapSerializer.java:536) at com.fasterxml.jackson.databind.ser.std.MapSerializer.serialize(MapSerializer.java:30) at com.fasterxml.jackson.databind.ser.DefaultSerializerProvider.serializeValue(DefaultSerializerProvider.java:292) at com.fasterxml.jackson.databind.ObjectMapper.writeValue(ObjectMapper.java:2509) at org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.writeInternal(MappingJackson2HttpMessageConverter.java:141)
时间: 2023-06-23 10:03:07 浏览: 398
这个错误是由于FastJson序列化JSONObject对象时,其中的文件类型是一个java.io.ByteArrayInputStream对象,而FastJson并不支持这种类型的序列化。解决方法可以尝试禁用序列化特性SerializationFeature.FAIL_ON_EMPTY_BEANS,或者使用其他支持java.io.ByteArrayInputStream序列化的JSON库。
相关问题
JavaRDD<String> rdd = sparkContext.textFile("D:\\data\\aaa.txt") 报Caused by: com.fasterxml.jackson.databind.JsonMappingException: Incompatible Jackson version: 2.9.1
这个错误是因为你的代码使用的 Jackson 版本与 Spark 依赖的 Jackson 版本不兼容所致。你可以尝试升级或降级 Jackson 版本,或者使用 Maven 或 Gradle 等构建工具来管理依赖关系,以确保 Spark 依赖的 Jackson 版本与你的代码所使用的版本一致。同时,你也可以检查一下你的项目中是否存在多个 Jackson 版本的依赖。
Caused by: com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `com.sitech.prom.channelsettle.rehearsal.busi.compute.vo.ListResponseVo` out of START_ARRAY token at [Source: (PushbackInputStream); line: 1, column: 1] at com.fasterxml.jackson.databind.exc.MismatchedInputException.from(MismatchedInputException.java:59) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.DeserializationContext.reportInputMismatch(DeserializationContext.java:1464) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.DeserializationContext.handleUnexpectedToken(DeserializationContext.java:1238) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.DeserializationContext.handleUnexpectedToken(DeserializationContext.java:1190) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.deser.BeanDeserializer._deserializeFromArray(BeanDeserializer.java:604) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.deser.BeanDeserializer._deserializeOther(BeanDeserializer.java:190) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:166) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:4482) ~[jackson-databind-2.11.0.jar:2.11.0] at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:3487) ~[jackson-databind-2.11.0.jar:2.11.0] at org.springframework.http.converter.json.AbstractJackson2HttpMessageConverter.readJavaType(AbstractJackson2HttpMessageConverter.java:239) ~[spring-web-5.2.6.RELEASE.jar:5.2.6.RELEASE] ... 21 common frames omitted
这是一个 Jackson 序列化/反序列化的报错信息,可能是由于在反序列化时,输入的 JSON 数据格式与需要的 Java 对象类型不匹配导致的。
具体来说,这个报错信息表明在反序列化时,期望得到一个类型为 `com.sitech.prom.channelsettle.rehearsal.busi.compute.vo.ListResponseVo` 的对象,但是实际输入的 JSON 数据是一个数组(START_ARRAY token)。
要解决这个问题,需要检查输入的 JSON 数据是否符合需要反序列化的 Java 对象的数据格式,以及确保 Jackson 库能够正确的反序列化这个数据。如果数据格式正确,可以考虑检查 Jackson 库的版本和配置是否正确,并且检查是否存在其他与反序列化相关的问题。
阅读全文