用Jackson序列化ImmutableMap

问题描述

我正在尝试使用Jackson序列化ImmutableMap 自定义序列化程序是专门为Dummy类编写的。其余的认行为都可以。 它对Dummy类有效,但不适用于ImmutableMap对象。

序列化器类:

public class DummySerializer extends StdSerializer<Dummy> {
    private final ObjectMapper mapper = new ObjectMapper();

    protected DummySerializer(Class<Dummy> t) {
        super(t);
    }

    @Override
    public void serialize(Dummy dummyObj,JsonGenerator gen,SerializerProvider serializers)
            throws IOException {

        StringWriter writer = new StringWriter();
        mapper.writeValue(writer,dummyObj.getDummyId());
        gen.writeFieldName(writer.toString());
    }
}

用法

ImmutableMap<Dummy,DummyInfo> map = //initialization
SimpleModule module = new SimpleModule();
module.addSerializer(new DummySerializer(Dummy.class));
ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(module);
mapper.writeValueAsstring(map);

输出是ImmutableMap的认字符串输出,而不是看到指定的序列化。

解决方法

使用addKeySerializer代替addSerializer解决了该问题。

SimpleModule module = new SimpleModule();
module.addKeySerializer(new DummySerializer(Dummy.class));

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...