gpt4 book ai didi

java - 将 avro 生成的对象序列化为 json 时出现 JsonMappingException

转载 作者:搜寻专家 更新时间:2023-10-31 19:37:13 28 4
gpt4 key购买 nike

我使用 avro-tools 从 avsc 文件生成 java 类,使用:

java.exe -jar avro-tools-1.7.7.jar compile -string schema myfile.avsc 

然后我尝试通过ObjectMapper将这些对象序列化为json,但总是有一个 JsonMappingException 说“不是枚举”或“不是联合”。在我的测试中,我使用它的构建器或构造函数创建生成的对象。对于不同类的对象,我得到了这样的异常......

示例代码:

ObjectMapper serializer = new ObjectMapper(); // com.fasterxml.jackson.databind
serializer.register(new JtsModule()); // com.bedatadriven.jackson.datatype.jts
...
return serializer.writeValueAsBytes(avroConvertedObject); // => JsonMappingException

我也尝试了许多配置使用:serializer.configure(...) 但仍然失败。版本:Java 1.8,jackson-datatype-jts 2.3, jackson 核心 2.6.5, jackson 数据绑定(bind) 2.6.5, jackson 注释 2.6.5

有什么建议吗?谢谢!

最佳答案

如果 SCHEMA 成员确实如此(我们没有看到完整的错误消息),那么您可以将其关闭。我使用 mixin 来做到这一点,就像这样:

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import org.apache.avro.Schema;
import org.junit.Test;

import java.io.File;
import java.io.IOException;

public class AvroGenerTests
{
abstract class IgnoreSchemaProperty
{
// You have to use the correct package for JsonIgnore,
// fasterxml or codehaus
@JsonIgnore abstract void getSchema();
}

@Test
public void writeJson() throws IOException {
BookAvro b = BookAvro.newBuilder()
.setTitle("Wilk stepowy")
.setAuthor("Herman Hesse")
.build();
ObjectMapper om = new ObjectMapper();
om.enable(SerializationFeature.INDENT_OUTPUT);
om.addMixIn(BookAvro.class, IgnoreSchemaProperty.class);
om.writeValue(new File("plik_z_gen.json"), b);
}
}

关于java - 将 avro 生成的对象序列化为 json 时出现 JsonMappingException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39349733/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com