dubbo之泛化引用
阿新 • • 發佈:2017-09-17
java urn void -h ive eric 獲取 max-width generics
使用泛化調用
泛化接口調用方式主要用於客戶端沒有 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" });
GenericService barService = (GenericService) applicationContext.getBean("barService");
Object result = barService.$invoke("sayHello", new String[] { "java.lang.String" }, new Object[] { "World" });
通過 API 方式使用泛化調用
import com.alibaba.dubbo.rpc.service.GenericService;
...
// 引用遠程服務
// 該實例很重量,裏面封裝了所有與註冊中心及服務提供方連接,請緩存
ReferenceConfig<GenericService> reference = new ReferenceConfig<GenericService>();
// 弱類型接口名
reference.setInterface("com.xxx.XxxService" );
reference.setVersion("1.0.0");
// 聲明為泛化接口
reference.setGeneric(true);
// 用com.alibaba.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");
dubbo之泛化引用