Dubbo3 使用泛化調用

2022-03-31 11:00 更新

實現一個通用的服務測試框架,可通過?GenericService ?調用所有服務實現

泛化接口調用方式主要用于客戶端沒有 API 接口及模型類元的情況,參數及返回值中的所有 POJO 均用 Map 表示,通常用于框架集成,比如:實現一個通用的服務測試框架,可通過 ?GenericService ?調用所有服務實現。

通過 Spring 使用泛化調用

在 Spring 配置申明 ?generic="true"?:

<dubbo:reference id="barService" interface="com.foo.BarService" generic="true" />

在 Java 代碼獲取 barService 并開始泛化調用:

GenericService barService = (GenericService) applicationContext.getBean("barService");
Object result = barService.$invoke("sayHello", new String[] { "java.lang.String" }, new Object[] { "World" });

通過 API 方式使用泛化調用

import org.apache.dubbo.rpc.service.GenericService; 
... 
 
// 引用遠程服務 
// 該實例很重量,里面封裝了所有與注冊中心及服務提供方連接,請緩存
ReferenceConfig<GenericService> reference = new ReferenceConfig<GenericService>(); 
// 弱類型接口名
reference.setInterface("com.xxx.XxxService");  
reference.setVersion("1.0.0");
// 聲明為泛化接口 
reference.setGeneric(true);  

// 用org.apache.dubbo.rpc.service.GenericService可以替代所有接口引用  
GenericService genericService = reference.get(); 
 
// 基本類型以及Date,List,Map等不需要轉換,直接調用 
Object result = genericService.$invoke("sayHello", new String[] {"java.lang.String"}, new Object[] {"world"}); 
 
// 用Map表示POJO參數,如果返回值為POJO也將自動轉成Map 
Map<String, Object> person = new HashMap<String, Object>(); 
person.put("name", "xxx"); 
person.put("password", "yyy"); 
// 如果返回POJO將自動轉成Map 
Object result = genericService.$invoke("findPerson", new String[]
{"com.xxx.Person"}, new Object[]{person}); 
 
...

有關泛化類型的進一步解釋

假設存在 POJO 如:

package com.xxx;

public class PersonImpl implements Person {
    private String name;
    private String password;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}

則 POJO 數據:

Person person = new PersonImpl(); 
person.setName("xxx"); 
person.setPassword("yyy");

可用下面 Map 表示:

Map<String, Object> map = new HashMap<String, Object>(); 
// 注意:如果參數類型是接口,或者List等丟失泛型,可通過class屬性指定類型。
map.put("class", "com.xxx.PersonImpl"); 
map.put("name", "xxx"); 
map.put("password", "yyy");


以上內容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號