示例
想完整的運行起來,請參見:快速啟動,這里只列出各種場景的配置方式
泛化引用
泛接口調用方式主要用於客戶端沒有API接口及模型類元的情況,參數及返回值中的所有POJO均用Map表示,通常用於框架集成,比如:實現一個通用的服務測試框架,可通過GenericService調用所有服務實現。
<dubbo:reference id="barService" interface="com.foo.BarService" generic="true" />
GenericService barService = (GenericService) applicationContext.getBean("barService");
Object result = barService.$invoke("sayHello", new String[] { "java.lang.String" }, new Object[] { "World" });
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); // 聲明為泛化接口 GenericService genericService = reference.get(); // 用com.alibaba.dubbo.rpc.service.GenericService可以替代所有接口引用 // 基本類型以及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"); Object result = genericService.$invoke("findPerson", new String[]{"com.xxx.Person"}, new Object[]{person}); // 如果返回POJO將自動轉成Map ...
假設存在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>(); map.put("class", "com.xxx.PersonImpl"); // 注意:如果參數類型是接口,或者List等丟失泛型,可通過class屬性指定類型。 map.put("name", "xxx"); map.put("password", "yyy");
啦啦啦
