一般情况下,调用feign接口需要注入FeignClient来调用,与dubbo类似,需要引入对应的接口包。在不注入对应client的情况下,feign又没有类似于dubbo的泛化调用的支持,我们可以通过Feign.builder()动态构建feignClient
CallbackAPI callbackAPI = Feign.builder()
.encoder(new SpringEncoder(feignHttpMessageConverter()))
.decoder(new SpringDecoder(feignHttpMessageConverter()))
.logger(new Slf4jLogger())
.logLevel(Logger.Level.FULL)
.target(CallbackAPI.class, "EMPTY"); // 注意:这里的url参数不能为空字符串,但是可以设置为任意字符串值,在这里设置为“EMPTY”
Object result = callbackAPI.callback(URI.create("registryAddress", applicationName+"/"+methodName, params);
//CallbackAPI 为定义的通用类,具体见下文
public interface CallbackAPI {
/**
* 统一回调接口方法,请求消息体格式为JSON,响应消息体格式也为JSON
* @param host 接口主机地址,如:http://localhost:8080,该参数是实现动态URL的关键
* @param path 接口路径,如:/test/hello
* @param queryMap 动态URL参数集合
* @return
*/
@RequestLine("POST {path}")
@Headers({
"Content-Type: application/json",
"Accept: application/json"
})
Object callback(URI host, @Param("path") String path, @QueryMap Map<String, Object> queryMap);
/**
* 统一回调接口方法,请求消息体格式为JSON,响应消息体格式也为JSON
* @param host 接口主机地址,如:http://localhost:8080,该参数是实现动态URL的关键
* @param path 接口路径,如:/test/hello
* @param queryMap 动态URL参数集合
* @param body 请求消息体对象
* @return
*/
@RequestLine("POST {path}")
@Headers({
"Content-Type: application/json",
"Accept: application/json"
})
Object callback(URI host, @Param("path") String path, @QueryMap Map<String, Object> queryMap, @RequestBody Object body);
/**
* 统一回调接口方法,请求消息体格式为JSON,响应消息体格式也为JSON
* @param uri 完整的请求路径地址,如:http://localhost:8080/test/hello
* @param queryMap 动态URL参数集合
* @return
*/
@RequestLine("POST")
@Headers({
"Content-Type: application/json",
"Accept: application/json"
})
Object callback(URI uri, @QueryMap Map<String, Object> queryMap);
}
仅做研究,Feign是一个声明式的REST客户端,在知道具体信息的情况下,完全可以通过http的方式调用