SpringCloud快速入门(8)---- OpenFeign(远程调用)

引入依赖:

XML 复制代码
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

1. 启动 / 核心注解

@EnableFeignClients加在启动类上,开启 OpenFeign 功能,表示这个服务开始远程调用功能。

@FeignClient加在调用接口的接口类上,标记这是 Feign 远程调用客户端。

其中value代表的是要调用哪个服务,如果要调用第三方服务,可以使用url属性,指定要发送请求的url

2. 请求映射注解

沿用的SpringBoot的注解,只不过区别是指定发送请求的类型

  • @GetMapping:发送get请求
  • @PostMapping:发送post请求
  • @PutMapping:发送put请求
  • @DeleteMapping:发送delete请求
java 复制代码
@FeignClient(value = "service-product")
public interface ProductFeignClient {
    @GetMapping("/product/{id}")
    Product getProductById(@PathVariable("id") Long id);
}

3. 参数绑定注解

同样沿用SpringBoot的注解:

  • @RequestParam:普通普通表单参数、URL 拼接参数必须加。Feign 中简单参数必须显式加 @RequestParam,否则报错。
  • @PathVariable:路径变量,如 /user/{id},必须加。
  • @RequestBody:JSON 对象传参,POST 请求传实体类用这个,只能用于 POST。
  • @RequestHeader:传递请求头参数,比如 token、登录凭证。
  • @RequestPart:文件上传时使用,传文件 + 参数。

使用时直接注入feign对象调用其中方法即可,openFeign会自动从注册中心获取服务并负载均衡的发送请求

相关推荐
小bo波10 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking11 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才14 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11115 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev18 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301419 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing20 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员
咖啡八杯1 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
用户128526116022 天前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java