首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >没有调用Spring JSON序列化程序和反序列化程序

没有调用Spring JSON序列化程序和反序列化程序
EN

Stack Overflow用户
提问于 2017-01-02 02:04:25
回答 0查看 902关注 0票数 0

我已经为com.google.common.collect.Table类编写了自定义序列化程序和反序列化程序。但是在MongoDB中持久化该对象时不会调用它。我使用的是Spring4、Spring-MongoDB 1.9和Jackson 2.8.4。下面是类和配置。你能告诉我这是怎么回事吗?我希望这些类在持久化和从MongoDB中检索时被调用。

代码语言:javascript
复制
public class TableSeserializer extends StdSerializer<Table> {

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    public TableSeserializer() {
        this(Table.class);
    }

    public TableSeserializer(Class<Table> t) {
        super(t);
    }

    @SuppressWarnings("unchecked")
    @Override
    public void serialize(Table value, JsonGenerator gen, SerializerProvider provider)
            throws IOException {
        gen.writeStartObject();
        value.rowMap().forEach((i,map) ->{
            try {
                gen.writeNumber((int)i);
                ((Map)map).forEach((k,v)->{
                    try {
                        gen.writeStartObject();
                        Object object = ((Map)map).get(k);
                        if (object instanceof HTMLInputTag) {
                            HTMLInputTag inputTag = (HTMLInputTag) object;
                            gen.writeObjectField(inputTag.getId(),inputTag);
                        }else{
                            gen.writeObjectField(object.toString(),object);
                        }

                        gen.writeEndObject();

                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                });

            } catch (IOException e) {
                e.printStackTrace();
            }
        });
        gen.writeEndObject();
    }
}

public class TableDeserializer extends StdDeserializer<Table<Integer, String, HTMLInputTag>> {

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    protected TableDeserializer(Class<?> vc) {
        super(vc);
    }

    public TableDeserializer() { 
        this(null); 
    }

    @Override
    public Table<Integer, String, HTMLInputTag> deserialize(JsonParser jsonparser, DeserializationContext ctxt)
            throws IOException, JsonProcessingException {
        String data = jsonparser.getText();
        ObjectMapper mapper = new ObjectMapper();
        JsonNode node = mapper.readTree(data);


        return null;
    }

}

弹簧配置

代码语言:javascript
复制
@Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        SimpleModule module = new SimpleModule();
        module.addSerializer(Table.class, new TableSeserializer());
        module.addDeserializer(Table.class, new TableDeserializer());
        Jackson2ObjectMapperBuilder builder = new Jackson2ObjectMapperBuilder().modules(module);

        converters.add(jacksonConverter(builder));
    }

    @Bean
    MappingJackson2HttpMessageConverter jacksonConverter(Jackson2ObjectMapperBuilder builder) {
        return new MappingJackson2HttpMessageConverter(builder.build());
    }

类中的注释

代码语言:javascript
复制
public class OrganizationAttributeMetaData extends CommonDomainAttributes implements Cloneable, Serializable {

    /**
     *
     */
    private static final long serialVersionUID = 1L;

    private String attributeName;
    private int orgid;
    private String uniquecode; //3 Character unique code to uniquely identify

    @JsonDeserialize(using=TableDeserializer.class)
    @JsonSerialize(using=TableSeserializer.class)
    Table<Integer, String, HTMLInputTag> htmlAttributes = null; //row,identifier and HTML

}
EN

回答

页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41417716

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档