Feign的使用(聲明式REST客戶端)

什麼是Feign?

Feign是一個集成了Ribbon的聲明式的Web服務客戶端。這使得Web服務客戶端的寫入更加方便 要使用Feign創建一個界面並對其進行註釋。它具有可插入註釋支持,包括Feign註釋和JAX-RS註釋。Feign還支持可插拔編碼器和解碼器。Spring Cloud增加了對Spring MVC註釋的支持,並使用Spring Web中默認使用的HttpMessageConverters。Spring Cloud集成Ribbon和Eureka以在使用Feign時提供負載均衡的http客戶端。

Feign的使用如下:

一、添加依賴

    <dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

二、在啓動類上加入@EnableFeignClients

@EnableFeignClients
@SpringBootApplication
@EnableEurekaClient
public class FeignApplication {
  public static void main(String[] args) {
    SpringApplication.run(FeignApplication.class, args);
  }
}

 三、新建一個接口(聲明式),使用@FeignClient註解

@FeignClient(name = "microservice-provider-user")
public interface UserFeignClient {

  @GetMapping("/users/{id}")
  User findById(@PathVariable("id") Long id);

}

說明:microservice-provider-user是服務提供者的Application Name。

 四、在需要使用Feign接口的地方引入即可使用

  @Autowired
  private UserFeignClient userFeignClient;

注意:參數是對象的話,即使代碼寫的是Get方法,feign也會自動變爲Post方法請求遠程服務的。

舉例:

  //服務提供方
  @GetMapping("/saveUser")
  public User saveUser(@RequestBody User user) {
    System.out.println(user.getUsername());
    return user;
  }
  
  //Feign客戶端
  @GetMapping("/users/saveUser")
  public User saveUser() {
    User user = new User();
    user.setUsername("river");
    return userFeignClient.saveUser(user);
  }
 
  //Feign聲明的接口
  @GetMapping("users/saveUser")
  User saveUser(@Param("user") User user);

 報錯:"status":405,"error":"Method Not Allowed","message":"Request method 'POST' not supported"

改正錯誤: 把服務提供方的請求方法改爲Post

  @PostMapping("/saveUser")
  public User saveUser(@RequestBody User user) {
    System.out.println(user.getUsername());
    return user;
  }

關於Feign的詳細使用,可以閱讀Spring-Cloud的文檔:https://www.springcloud.cc/spring-cloud-dalston.html#spring-cloud-feign

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章