Apache Dubbo Gson 序列化扩展教程

Apache Dubbo Gson 序列化扩展教程

dubbo-serialization-gsonDubbo gson serialization extension项目地址:https://gitcode.com/gh_mirrors/du/dubbo-serialization-gson

1. 项目的目录结构及介绍

dubbo-serialization-gson/
├── src/
│   ├── main/
│   │   ├── java/
│   │   │   └── org/
│   │   │       └── apache/
│   │   │           └── dubbo/
│   │   │               └── serialization/
│   │   │                   └── gson/
│   │   │                       ├── GsonSerialization.java
│   │   │                       └── GsonSerializationFactory.java
│   │   └── resources/
│   └── test/
│       ├── java/
│       │   └── org/
│       │       └── apache/
│       │           └── dubbo/
│       │               └── serialization/
│       │                   └── gson/
│       │                       └── GsonSerializationTest.java
│       └── resources/
├── .gitignore
├── LICENSE
├── README.md
├── pom.xml

目录结构介绍

  • src/main/java/org/apache/dubbo/serialization/gson/: 包含主要的 Gson 序列化实现类。
    • GsonSerialization.java: Gson 序列化核心类。
    • GsonSerializationFactory.java: Gson 序列化工厂类。
  • src/test/java/org/apache/dubbo/serialization/gson/: 包含测试类。
    • GsonSerializationTest.java: Gson 序列化测试类。
  • src/main/resources/src/test/resources/: 包含项目所需的资源文件。
  • .gitignore: Git 忽略文件配置。
  • LICENSE: 项目许可证文件。
  • README.md: 项目说明文档。
  • pom.xml: Maven 项目配置文件。

2. 项目的启动文件介绍

GsonSerialization.java

package org.apache.dubbo.serialization.gson;

import com.google.gson.Gson;
import org.apache.dubbo.common.serialize.ObjectOutput;
import org.apache.dubbo.common.serialize.ObjectInput;
import org.apache.dubbo.common.serialize.Serialization;

public class GsonSerialization implements Serialization {
    private final Gson gson = new Gson();

    @Override
    public ObjectOutput serialize(OutputStream output) throws IOException {
        return new GsonObjectOutput(output, gson);
    }

    @Override
    public ObjectInput deserialize(InputStream input) throws IOException {
        return new GsonObjectInput(input, gson);
    }
}

GsonSerializationFactory.java

package org.apache.dubbo.serialization.gson;

import org.apache.dubbo.common.extension.ExtensionFactory;
import org.apache.dubbo.common.extension.ExtensionLoader;
import org.apache.dubbo.common.serialize.Serialization;

public class GsonSerializationFactory implements ExtensionFactory {
    @Override
    public <T> T getExtension(Class<T> type, String name) {
        if (type == Serialization.class && "gson".equals(name)) {
            return (T) new GsonSerialization();
        }
        return null;
    }
}

3. 项目的配置文件介绍

pom.xml

<dependencies>
    <dependency>
        <groupId>org.apache.dubbo.extensions</groupId>
        <artifactId>dubbo-serialization-gson</artifactId>
        <version>1.0.1</version>
    </dependency>
    <dependency>
        <groupId>com.google.code.gson</groupId>
        <artifactId>gson</artifactId>
        <version>2.10.1</version>
    </dependency>
</dependencies>

application.yml (Spring Boot)

dubbo:
  protocol:
    serialization: gson

dubbo.properties

dubbo.protocol.serialization=gson
# or
dubbo.consumer.serialization=gson
# or
dubbo.reference.com.demo.DemoService.serialization=gson

以上是 Apache Dubbo Gson 序列化扩展项目的详细教程,包含了项目的目录结构、启动文件和配置文件的介绍。希望对您有所

dubbo-serialization-gsonDubbo gson serialization extension项目地址:https://gitcode.com/gh_mirrors/du/dubbo-serialization-gson

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宋韵庚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值