Dubbo Jackson序列化使用说明

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Dubbo Jackson序列化使用说明相关的知识,希望对你有一定的参考价值。

文档版权:Creative Commons 3.0许可证 署名-禁止演绎

Jackson序列化提供了对基本数据类型和简单Bean的序列化的支持, 以及对类继承的支持。

已经经过测试的数据类型包括:

Boolean/boolean
Long/long
Integer/int
Double/double
Short/short
Float/float
Byte/byte
java.util.Date
org.joda.time.DateTime

以及由这些基本数据类型组成的数组和Bean, 如 int[], String[]等.

jackson序列化使用

<dubbo:protocol name="dubbo" port="20880" serialization="jackson" />

自定义ObjectMapper

默认情况下,Jackson序列化和反序列化时所使用的ObjectMapper定义如下:

  @Override
    public ObjectMapper getObjectMapper() {
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.disable(SerializationFeature.FAIL_ON_EMPTY_BEANS);
//            objectMapper.disable(SerializationFeature.FLUSH_AFTER_WRITE_VALUE);
        objectMapper.disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);
        objectMapper.setTimeZone(TimeZone.getDefault());
        return objectMapper;
}

如果需要自定义JacksonObjectMapperProvider, 开发者可以通过实现com.alibaba.dubbo.common.json.JacksonObjectMapperProvider接口进行自定义,并在/META-INF/dubbo/中添加文件 com.alibaba.dubbo.common.json.JacksonObjectMapperProvider,内容示例如下:

jackson=com.alibaba.dubbo.examples.jackson.jacksonprovider.CustomJacksonObjectMapperProvider

已知问题

  1. 不支持泛型对象的序列化, 如 List,Map类型的序列化和反序列化

以上是关于Dubbo Jackson序列化使用说明的主要内容,如果未能解决你的问题,请参考以下文章

Dubbo——Dubbo协议整合Jackson序列化解决方案

Dubbo Jackson序列化使用说明

Dubbo Jackson序列化使用说明

Jackson序列化(8)— 支持泛型的反序列化

再谈序列化之rpc调用失败和jackson序列化时不允许Map中的key为null

使用 Jackson 序列化通用接口子类