使用Feign时如何设置Feign的Header信息

本文介绍了在Feign中通过两种方式为HTTP请求头添加自定义信息的方法:一是利用注解`@Headers`直接在请求或类级别声明静态或动态Header;二是通过实现`RequestInterceptor`接口来统一为所有Feign请求设置Header。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Feign 调用接口是经常会忘header信息,再次介绍两种忘header里面添加信息的方式:

1. 通过直接在请求上,或者在类上添加Headers的注解

@Headers({"Content-Type: application/json","Accept: application/json",Accept {contentType}})
@PostMapping(value = "/card-blank/batch-create")
Response batchCreateCard(@RequestBody CreateCardBlankDTO condition,@Param("contentType") String type);

使用{contentType} 可以传递动态header属性

2. 通过实现RequestInterceptor接口,完成对所有的Feign请求,设置Header

import feign.RequestInterceptor;
import feign.RequestTemplate;
import org.springframework.stereotype.Component;

@Component
public class FeignInterceptor implements RequestInterceptor{

    public void apply(RequestTemplate requestTemplate){
        requestTemplate.header("hotelId", "111111");
    }
}

这种方式也可以设置请求的其他属性,很灵活的一种方式:

转载于:https://my.oschina.net/aulbrother/blog/1610011

### 如何在Spring Cloud Feign客户端中设置自定义Header #### 方法一:通过`@RequestLine`或`@Headers`注解 OpenFeign 提供了原生的支持,可以通过 `@Headers` 注解直接为某个 Feign 接口的方法添加固定的 HTTP Header。这种方式适用于静态的 Header 设置。 ```java @FeignClient(name = "exampleService", url = "http://example.com") public interface ExampleClient { @Headers("Authorization: Bearer token") // 静态Header设置 @GetMapping("/api/resource") String getResource(); } ``` 上述代码展示了如何使用 `@Headers` 注解为特定方法添加固定值的 Header[^4]。 --- #### 方法二:动态设置Header 如果需要根据运行条件动态设置 Header,则可以利用 `RequestInterceptor` 实现全局或者局部范围内的动态 Header 添加逻辑。 ##### 步骤说明 1. 创建一个实现 `RequestInterceptor` 接口的类。 2. 在该拦截器中修改请求头信息。 3. 将此拦截器注册到 Spring 容器中。 以下是具体代码示例: ```java import feign.RequestInterceptor; import feign.RequestTemplate; @Component public class CustomFeignInterceptor implements RequestInterceptor { @Override public void apply(RequestTemplate template) { // 动态设置Header template.header("Custom-Header-Key", "DynamicHeaderValue"); template.header("Authorization", "Bearer " + getTokenFromSomewhere()); } private String getTokenFromSomewhere() { // 获取实际Token的逻辑 return "your-dynamic-token"; } } ``` 在此配置下,所有的 Feign 请求都会自动带上由 `apply()` 方法设定的 Headers[^2]。 --- #### 方法三:基于`@RequestMapping`注解的方式 对于某些场景,可能更倾向于使用标准的 Spring MVC 注解风格而非 OpenFeign 原生注解。此可以直接依赖于 `@RequestParam`, `@RequestBody` 或者其他参数绑定机制间接传递 Header 数据。 例如,在服务间通信过程中,可以从当前上下文中提取必要的认证信息并注入目标系统的 Header 中: ```java @RestController public class MyController { @Autowired private RestTemplate restTemplate; @GetMapping("/proxy-call") public ResponseEntity<String> proxyCall(@RequestHeader("Authorization") String authHeader) { HttpHeaders headers = new HttpHeaders(); headers.set("Authorization", authHeader); HttpEntity<Void> requestEntity = new HttpEntity<>(headers); return restTemplate.exchange( "http://target-service/api/data", HttpMethod.GET, requestEntity, String.class ); } } ``` 尽管这不是严格意义上的 Feign 解决方案,但在特殊需求下也是一种可行的选择[^1]。 --- #### 总结 以上介绍了三种主要方式用于解决在 Spring Cloud Feign 调用期间设置自定义 HTTP Header 的问题。推荐优先考虑 **方法二 (RequestInterceptor)** ,因为它既灵活又易于维护,特别适合跨多个 API 调用共享相同 Header 场景下的应用开发工作流。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值