dubbo泛化调用

我会带着你远行 2022-06-14 03:16 203阅读 0赞

dubbo泛化调用

一、前言

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

二、调用示列

方式一: xml声明dubbo reference

  1. <dubbo:reference id="valueService" interface="cn.pomelo.client.intf.IListValueService" generic="true" />
  2. GenericService barService = (GenericService) applicationContext.getBean("valueService");
  3. // 用Map表示POJO参数,如果返回值为POJO也将自动转成Map
  4. Map<String, Object> cache = new HashMap<>();
  5. cache.put("type", "mobile");
  6. cache.put("value", "18969975142");
  7. // 基本类型以及Date,List,Map等不需要转换,直接调用
  8. Object result = genericService.$invoke("getCache",
  9. new String[] { "cn.pomelo.client.pojo.request.ListQueryBean" },
  10. new Object[] { cache });

方式二:xml不声明dubbo reference

  1. @Autowired
  2. private ReferenceConfig<GenericService> referenceConfig;
  3. public Object genericInvoker() {
  4. // 引用远程服务
  5. ReferenceConfig<GenericService> reference = new ReferenceConfig<>(); // 该实例很重量,里面封装了所有与注册中心及服务提供方连接,请缓存
  6. reference.setInterface("cn.pomelo.client.intf.IListValueService"); // 弱类型接口名
  7. reference.setVersion("1.0.0");
  8. reference.setGeneric(true); // 声明为泛化接口
  9. reference.setApplication(referenceConfig.getApplication());
  10. reference.setRegistry(referenceConfig.getRegistry());
  11. GenericService genericService = reference.get(); // 用com.alibaba.dubbo.rpc.service.GenericService可以替代所有接口引用
  12. // 用Map表示POJO参数,如果返回值为POJO也将自动转成Map
  13. Map<String, Object> cache = new HashMap<>();
  14. cache.put("type", "mobile");
  15. cache.put("value", "18969975142");
  16. // 基本类型以及Date,List,Map等不需要转换,直接调用
  17. Object result = genericService.$invoke("getCache",
  18. new String[] { "cn.pomelo.client.pojo.request.ListQueryBean" },
  19. new Object[] { cache });
  20. return result;
  21. }

发表评论

表情:
评论列表 (有 0 条评论,203人围观)

还没有评论,来说两句吧...

相关阅读

    相关 dubbo调用

    dubbo泛化调用 一、前言 > 泛接口调用方式主要用于客户端没有API接口及模型类元的情况,参数及返回值中的所有POJO均用Map表示,通常用于框架集成,比如:实