dubbo泛化调用

dubbo泛化调用

一、前言

泛接口调用方式主要用于客户端没有API接口及模型类元的情况,参数及返回值中的所有POJO均用Map表示,通常用于框架集成,比如:实现一个通用的服务测试框架,可通过GenericService调用所有服务实现。

二、调用示列

方式一: xml声明dubbo reference

<dubbo:reference id="valueService" interface="cn.pomelo.client.intf.IListValueService" generic="true" />
GenericService barService = (GenericService) applicationContext.getBean("valueService");

// 用Map表示POJO参数,如果返回值为POJO也将自动转成Map
Map<String, Object> cache = new HashMap<>();
cache.put("type", "mobile");
cache.put("value", "18969975142");

// 基本类型以及Date,List,Map等不需要转换,直接调用
Object result = genericService.$invoke("getCache",
                                       new String[] { "cn.pomelo.client.pojo.request.ListQueryBean" },
                                       new Object[] { cache });

方式二:xml不声明dubbo reference

 @Autowired
 private ReferenceConfig<GenericService> referenceConfig;

 public Object genericInvoker() {
    // 引用远程服务
    ReferenceConfig<GenericService> reference = new ReferenceConfig<>(); // 该实例很重量,里面封装了所有与注册中心及服务提供方连接,请缓存
    reference.setInterface("cn.pomelo.client.intf.IListValueService"); // 弱类型接口名
    reference.setVersion("1.0.0");
    reference.setGeneric(true); // 声明为泛化接口
    reference.setApplication(referenceConfig.getApplication());
    reference.setRegistry(referenceConfig.getRegistry());

    GenericService genericService = reference.get(); // 用com.alibaba.dubbo.rpc.service.GenericService可以替代所有接口引用

    // 用Map表示POJO参数,如果返回值为POJO也将自动转成Map
    Map<String, Object> cache = new HashMap<>();
    cache.put("type", "mobile");
    cache.put("value", "18969975142");
    // 基本类型以及Date,List,Map等不需要转换,直接调用
    Object result = genericService.$invoke("getCache",
                                           new String[] { "cn.pomelo.client.pojo.request.ListQueryBean" },
                                           new Object[] { cache });

    return result;
}
阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zhengyong15984285623/article/details/72911834
文章标签: dubbo
个人分类: dubbo
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭