自定义Feign客户端的使用

1 概述
Java在进行http调用时, 通常会使用以下几种方式:

  • HttpClient
  • HttpUrlConnection
  • RestTemplate
  • Feign
    其中,RestTemplate 和 Feign相对于前面两种调用方式来说明显起来明显更加优雅和方便,也更符合我们的语法习惯。 而RestTemplate 和 Feign的使用各有优缺点,相对Feign而言,RestTemplate 使用更加灵活,有较好的扩展性。而Feign虽然扩展性一般,但在处理一些简单调用时,不管是开发体验,还是可读性以及可维护性,都不是RestTemplate所能比拟的。下面从具体案例进行说明,阐述两者分别存在的弊端,并尝试能够结合两者优点的调用方式。

2 案例
2.1 代码比对
假如我们现在需要向 http://xxx 的网址获取用户信息, 使用RestTemplate的调用代码如下:

//代码块1.1
@Component
public class UserServiceRestClient {
   
 
    @Autowired
    private RestTemplate restTemplate;
 
    BaseResult<UserDetailDto> getUserDetail(Param4User param4User) {
   
        String url = "http://xxx" + "/api/user/detail/get";
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_JSON_UTF8);
        HttpEntity entity = new HttpEntity<>(param4User, headers);
        return restTemplate.exchange(url, HttpMethod.POST, entity,
                new ParameterizedTypeReference<BaseResult<UserDetailDto>>(){
   }).getBody();
    }
}

直接使用代码块1.1的灵活性自然是最好的,无论是后续进行参数或者结果处理,或是需要添加验证、握手机制等,都可以直接在方法内扩展。但是这样一来,后续的维护工作量就可能会大大增加,特别是有复杂握手机制的情况下。所以,正常情况下,我们可能会考虑牺牲一定的灵活性进行一定程度的封装,如下:

//代码块1.2
@Component
public class BaseRestTemplate {
   
 
    @Autowired
    private RestTemplate restTemplate;
 
    public <T, R> T exchange(String url, HttpMethod method, R param,
                                ParameterizedTypeReference<T> responseType, Object... uriVariables)  {
   
        String invokeUrl = "http://xxx" + url;
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_JSON_UTF8);
        HttpEntity entity = new HttpEntity<>(param, headers);
        return restTemplate.exchange(invokeUrl, method, entity, responseType, uriVariables).getBody();
    }
}

这时,RestTemplate的业务调用代码变为:

//代码块1.3
@Component
public class UserServiceRestClient {
   
 
    @Autowired
    private BaseRestTemplate baseRestTemplate;
 
    BaseResult<UserDetailDto> getUserDetail(Param4User param4User) {
   
        return baseRestTemplate.exchange("/api/user/detail/get", HttpMethod.POST, param4User,
        new ParameterizedTypeReference<BaseResult<UserDetailDto>>(){
   });
    }
}

而使用Feign的业务调用代码为:

//代码块1.4
@FeignClient(url = "http://xxx")
@Headers({
   "Accept: application/json", "Content-Type: application/json"})
public interface UserServiceClient {
   
 
    @RequestLine("POST /api/user/detail/get")
    BaseResult<UserDetailDto> getUserDetail(Param4User param4User);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值