Feign調(diào)用

Feign是Netflix開發(fā)的聲明試、模版化的HTTP客戶端,它調(diào)用HTTP API更加便捷優(yōu)雅。

一、基礎(chǔ)應(yīng)用

1.feign使用

增加feign依賴
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
編寫feign接口
@FeignClient(name = "microservice-provider-user")
public interface UserFeignClient {
    @PostMapping("/api/user")
    String find();
}

@FeignClient注解的name 是指定FeignClient的名稱,如果項(xiàng)目使用了Ribbon\Consul等,name屬性會(huì)作為微服務(wù)的名稱,用于服務(wù)發(fā)現(xiàn)。還可以使用url可以手動(dòng)指定@FeignClient調(diào)用的地址。

啟用feign

啟動(dòng)類增加 @EnableFeignClients 注解

調(diào)試
    @PostMapping("/serviceInstance")
    public String serviceInstance() {
        return userFeignClient.find();
    }

結(jié)果:

[{"id":1,"username":"account1","name":"張三","age":20,"balance":150.00},
{"id":2,"username":"account2","name":"李四","age":25,"balance":350.00},
{"id":3,"username":"account3","name":"王五","age":28,"balance":450.00}]

2.feign自定義配置

SpringCloud中Feign默認(rèn)配置類是FeignClientsConfiguration,我們可以通過@FeignClient的configuration屬性自定義配置,自定義配置的優(yōu)先級會(huì)比FeignClientsConfiguration高。

創(chuàng)建Feign配置類
import feign.Contract;
import feign.Logger;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class FeignConfig {

    @Bean
    public Contract feignContract() {
        return new feign.Contract.Default();
    }

    @Bean
    public Logger.Level feignLoggerLevel() {
        return Logger.Level.FULL;
    }
}

以上包含兩項(xiàng)配置更改,使用Feign默認(rèn)契約和打印FULL級別的日志。

feign接口
@FeignClient(name = "microservice-provider-user", configuration = FeignConfig.class)
public interface UserFeignClient {

    @RequestLine("POST /api/user")
    String find();

}

注意使用feign自帶注解@RequestLine , 如果依然使用 @PostMapping會(huì)報(bào)如下錯(cuò)誤:

- Class UserFeignClient has annotations [FeignClient] that are not used by contract Default
- Method find has an annotation PostMapping that is not used by contract Default

原因是FeignClientsConfiguration類(如下代碼),F(xiàn)eign默認(rèn)使用的契約是SpringMvcContract,而通過自定義配置已經(jīng)更改成Feign契約,因此需要使用Feign的注解。

    @Bean
    @ConditionalOnMissingBean
    public Contract feignContract(ConversionService feignConversionService) {
        return new SpringMvcContract(this.parameterProcessors, feignConversionService);
    }
調(diào)試結(jié)果

部分日志如下,有feign FULL日志,結(jié)果正常返回

[UserFeignClient#find] ---> POST http://microservice-provider-user/api/user HTTP/1.1
[UserFeignClient#find] ---> END HTTP (0-byte body)
[UserFeignClient#find] <--- HTTP/1.1 200 (206ms)
[UserFeignClient#find] connection: keep-alive
[UserFeignClient#find] content-type: application/json
[UserFeignClient#find] date: Tue, 13 Oct 2020 03:32:43 GMT
[UserFeignClient#find] keep-alive: timeout=60
[UserFeignClient#find] transfer-encoding: chunked
[UserFeignClient#find] 
[UserFeignClient#find] [{"id":1,"username":"account1","name":"張三","age":20,"balance":150.00}]
[UserFeignClient#find] <--- END HTTP (220-byte body)

3.feign多參數(shù)請求

Get請求多參數(shù)URL,如下兩種寫法

    @GetMapping("/api/user")
    String find(@RequestParam("id") String id, @RequestParam("name") String name);

    @GetMapping("/api/user")
    String find(@RequestParam Map<String, Object> map);
    

Post請求包含多參數(shù)

    @PostMapping("/api/user")
    String find(@RequestBody User user);

github:https://github.com/OpenFeign/feign/#basics

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容