每天学点SpringCloud(四):Feign的使用及自定义配置

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。博客源地址为zhixiang.org.cn https://blog.csdn.net/myFirstCN/article/details/81009750 Feign:SpringCloud的官网对它的定义是这样的:是一个声明式的Web服务客户端。
版权声明:本文为博主原创文章,未经博主允许不得转载。博客源地址为zhixiang.org.cn https://blog.csdn.net/myFirstCN/article/details/81009750

Feign:SpringCloud的官网对它的定义是这样的:

是一个声明式的Web服务客户端。它支持Feign本身的注解、JAX-RS注解以及SpringMVC的注解。Spring Cloud集成Ribbon和Eureka以在使用Feign时提供负载均衡的http客户端。

 

Feign的使用

 

我们先来看一看如何在项目中使用Feign

 

1. 首先呢 ,我们把原先的cloud-demo-consumer项目复制一份,artifactId改为cloud-demo-consumer-feign,然后添加依赖 (温馨提醒,没有看过前几篇文章的朋友,建议先从第一篇文章开始学习效果更佳哦 每天学点SpringCloud(一):使用SpringBoot2.0.3整合SpringCloud

        <dependency>
      <groupId>org.springframework.cloud</groupId>
      <!--注意此处的依赖是SpringBoot2.0以后专用的,如果您使用的SpringBoot版本低于2.0请使用spring-cloud-starter-feign-->
      <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
<dependency>
      <groupId>org.springframework.cloud</groupId>
      <!--注意此处的依赖是SpringBoot2.0以后专用的,如果您使用的SpringBoot版本低于2.0请使用spring-cloud-starter-feign-->
      <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

 

2.CloudDemoConsumerApplication启动类改名为CloudDemoConsumerFeignApplication,删除上次使用的RestTemplate,并在类上添加注解@EnableFeignClients,标示此项目为Feign客户端

@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class CloudDemoConsumerFeignApplication {

   public static void main(String[] args) {
      SpringApplication.run(CloudDemoConsumerFeignApplication.class, args);
   }
}

@EnableEurekaClient
@EnableFeignClients
public class CloudDemoConsumerFeignApplication {

   public static void main(String[] args) {
      SpringApplication.run(CloudDemoConsumerFeignApplication.class, args);
   }
}

 

3.在cn.org.zhixiang包下增加feign包 然后添加UserFeignClient接口:

@FeignClient("provider-demo")
public interface UserFeignClient {

 @GetMapping (value = "/user/getUser/{id}")
 public User getUser(@PathVariable("id")Long id);
}

("provider-demo")
public interface UserFeignClient {

 @GetMapping (value = "/user/getUser/{id}")
 public User getUser(@PathVariable("id")Long id);
}

这个接口呢,就是我们使用Feign的关键了,我们先来看一下@FeignClient("provider-demo")注解,它括号里的内容 看着是不是很熟悉,这不就是我们的服务提供者的名称么,对其实它就是我们需要调用的服务的spring.application.name。

接着是@RequestMapping(value = "/user/getUser/{id}", method = RequestMethod.GET)

@PathVariable("id"),这个注解咋还写上value了呢,我记得没写过呀,其实这就是一个坑了,如果不写的话是启动不起来滴。

 

4.接着我们看UserController类,刚才我们已经把RestTemple的Bean给干掉了,那么在这断然没有在使用它的道理。

我们现在要使用的就是我们刚才定义的UserFeignClient 接口

@RestController
@RequestMapping("/user")
public class UserController {

  @Autowired
  private UserFeignClient userFeignClient;

  @GetMapping("/getUser/{id}")
  public User getUser(@PathVariable Long id){
     return userFeignClient.getUser(id);
  }
}


@RequestMapping("/user")
public class UserController {

  @Autowired
  private UserFeignClient userFeignClient;

  @GetMapping("/getUser/{id}")
  public User getUser(@PathVariable Long id){
     return userFeignClient.getUser(id);
  }
}

5现在我们就可以测试了,先启动Eureka服务,然后随便启动我们定义的两个服务提供者中的其中一个,最后启动我们的这个项目。

浏览器访问http://localhost:8089/user/getUser/1,不知道你获取到数据了么?

 

修改Feign的默认配置

 

修改Feign的默认配置其实也存在包扫描的问题,因为上一篇文章(自定义Eureka集群负载均衡策略)已经讲过了,这里就不浪费时间了,没有看过的同学可以先去参考一下。

 

这里我们就简单省事,把配置文件放到ComponentScan扫描不到的地方吧:cn.org.config,在这里呢,我们新建了Configuration配置类

 

@org.springframework.context.annotation.Configuration
public class Configuration {
  @Bean
  public Contract feignContract() {
    return new Contract.Default();
  }
}
org.springframework.context.annotation.Configuration
public class Configuration {
  @Bean
  public Contract feignContract() {
    return new Contract.Default();
  }
}

 

然后在UserFeignClient类中指定configuration

@FeignClient(value = "provider-demo",configuration = Configuration.class)
value = "provider-demo",configuration = Configuration.class)

注意,我们在此类中修改了Feign的Contract ,那么Contract 是什么呢。它叫做契约。因为Feign一开始使用的契约是SpringMVC,所以刚才我们SpringMVC的注解的时候直接成功了,但是你如果现在启动项目你就会发现已经启动不了了。因为Contract.Default()使用的契约是Feign自己的,也就是说我们要把SpringMVC的注解修改为Feign的注解

 

SpringMVC版本

@GetMapping (value = "/user/getUser/{id}")
public User getUser(@PathVariable("id")Long id);
 (value = "/user/getUser/{id}")
public User getUser(@PathVariable("id")Long id);

Feign版本

@RequestLine("GET /user/getUser/{id}")
 public User getUser(@Param("id") Long id);
("GET /user/getUser/{id}")
 public User getUser(@Param("id") Long id);

 

当你学会修改Feign的契约时修改别的默认同样不在话下了已经。

 

GitHub:https://github.com/2388386839/spring-cloud-demo

码云:https://gitee.com/zhixiang_blog/spring-cloud-demo

 

如果对您有所帮助,请记得帮忙点一个star哦

 

 

本文出自https://zhixiang.org.cn,转载请保留。

相关文章
|
8天前
|
存储 Java 数据安全/隐私保护
|
6天前
|
应用服务中间件 nginx 微服务
SpringCloud解决feign调用token丢失问题
【5月更文挑战第2天】在feign调用中可能会遇到如下问题: * 同步调用中,token丢失,这种可以通过创建一个拦截器,将token做透传来解决 * 异步调用中,token丢失,这种就无法直接透传了,因为子线程并没有**token**,这种需要先将token从父线程传递到子线程,再进行透传
177 3
|
8天前
|
安全 Java 开发者
深入理解Spring Boot配置绑定及其实战应用
【4月更文挑战第10天】本文详细探讨了Spring Boot中配置绑定的核心概念,并结合实战示例,展示了如何在项目中有效地使用这些技术来管理和绑定配置属性。
17 1
|
8天前
|
XML Java 数据格式
Spring高手之路18——从XML配置角度理解Spring AOP
本文是全面解析面向切面编程的实践指南。通过深入讲解切面、连接点、通知等关键概念,以及通过XML配置实现Spring AOP的步骤。
24 6
Spring高手之路18——从XML配置角度理解Spring AOP
|
8天前
|
消息中间件 开发框架 Java
什么是Spring Boot 自动配置?
Spring Boot 是一个流行的 Java 开发框架,它提供了许多便利的功能和工具,帮助开发者快速构建应用程序。其中一个最引人注目的特性是其强大的自动配置功能。
14 0
|
8天前
|
XML SQL Java
SpringCloud 基础配置
SpringCloud 基础配置
14 0
|
8天前
|
Java Spring
Spring文件配置以及获取
Spring文件配置以及获取
15 0
|
8天前
|
Java 微服务 Spring
Spring Boot中获取配置参数的几种方法
Spring Boot中获取配置参数的几种方法
22 2
|
8天前
|
JSON Java Apache
Spring Cloud Feign 使用Apache的HTTP Client替换Feign原生httpclient
Spring Cloud Feign 使用Apache的HTTP Client替换Feign原生httpclient
|
8天前
|
消息中间件 安全 Java
在Spring Bean中,如何通过Java配置类定义Bean?
【4月更文挑战第30天】在Spring Bean中,如何通过Java配置类定义Bean?
22 1