Feign 请求拦截器和日志

本文介绍如何在Feign中使用请求拦截器,通过自定义实现RequestInterceptor接口,可在发送请求前添加请求头进行身份验证。同时,展示了如何配置日志级别以详细记录接口调用情况。

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

Feign 支持请求拦截器,在发送请求前,可以对发送的模板进行操作,例如设置请求头等属性,自定请求拦截器需要实现 feign.RequestInterceptor 接口,该接口的方法 apply 有参数 template ,该参数类型为 RequestTemplate,我们可以根据实际情况对请求信息进行调整,示例如下:

  • 创建拦截器

    创建自定义请求拦截器,在发送请求前增加了一个请求头信息,进行身份校验。

    package org.lixue.feignclient;

       

    import feign.RequestInterceptor;

    import feign.RequestTemplate;

       

    public class MyRequestInterceptor implements RequestInterceptor{

       

    public void apply(RequestTemplatetemplate){

    template.header("Authorization","lixue:123456");

    }

    }

  • 附加拦截器

    在使用时,如果需要附加拦截器和附加编码器、解码器的操作类似,示例如下:

    HelloWorldClientspeakClient=

    Feign.builder().requestInterceptor(new MyRequestInterceptor())

    .target(HelloWorldClient.class,"http://localhost:8080/");

       

  • 测试验证

    在默认情况下,不会记录接口的日志,如果需要了解接口的调用情况,可以使用 logLevel 方法进行配置日志级别:

    • NONE:默认值,不进行日志记录
    • BASIC:记录请求方法、URL、响应状态代码和执行时间
    • HEADERS:除了 BASIC 记录的信息外,还包括请求头和响应头
    • FULL:记录全部日志,包括请求头、请求体、请求与响应的元数据

    配置日志级别为 FULL,我们测试验证拦截器是否生效,代码如下:

    public class Startup{

    public static void main(String[]args){

    HelloWorldClientspeakClient=

    Feign.builder().client(new MyClient())

    .logLevel(Logger.Level.FULL)

    .logger(new Logger.JavaLogger().appendToFile("E:\\Temp\\logs\\speak.log"))

    .requestInterceptor(new MyRequestInterceptor())

    .target(HelloWorldClient.class,"http://localhost:8080/");

    System.out.println(speakClient.speak("isbody"));

    }

    }

    启动项目,然后查看日志如下:

    [HelloWorldClient#speak] ---> GET http://localhost:8080/speak?body=is+body HTTP/1.1

    [HelloWorldClient#speak] Authorization: lixue:123456

    [HelloWorldClient#speak] ---> END HTTP (0-byte body)

    [HelloWorldClient#speak] <--- HTTP/1.1 200 (790ms)

    [HelloWorldClient#speak] content-length: 23

    [HelloWorldClient#speak] content-type: text/plain;charset=UTF-8

    [HelloWorldClient#speak] date: Thu, 05 Apr 2018 11:40:27 GMT

    [HelloWorldClient#speak] x-application-context: helloworld-provider:8080

    [HelloWorldClient#speak]

    [HelloWorldClient#speak] speak is body port:8080

    [HelloWorldClient#speak] <--- END HTTP (23-byte body)

    在请求头中,已经增加了 Authorization: lixue:123456 数据

转载于:https://www.cnblogs.com/duanxz/p/9760052.html

### 如何在Feign拦截器中处理响应Token 为了实现通过Feign拦截器处理响应中的Token,通常需要自定义`RequestInterceptor`以及监听并解析HTTP响应头。以下是具体方法: #### 自定义Feign拦截器 可以通过继承`RequestInterceptor`类来自定义请求拦截逻辑,在其中设置必要的请求头信息。 ```java import feign.RequestInterceptor; import feign.RequestTemplate; public class CustomFeignInterceptor implements RequestInterceptor { @Override public void apply(RequestTemplate template) { // 设置请求头参数,比如 Access-Token 或其他认证信息 String accessToken = "your_access_token"; // 这里可以从上下文中动态获取 Token template.header("Authorization", "Bearer " + accessToken); } } ``` 上述代码展示了如何向每个Feign请求添加特定的Header字段[^3]。 #### 配置Feign客户端以支持拦截器 为了让Feign客户端能够应用自定义的拦截器,需将其注册到Spring容器中。 ```yaml feign: client: config: default: loggerLevel: FULL # 开启完整的日志记录以便调试 ``` 以上YAML配置文件片段用于启用详细的日志输出,便于观察Http请求的具体情况[^2]。 #### 解析响应头部提取Token 虽然Feign本身不提供直接的方式去操作响应体之外的数据(如Headers),但是可以借助装饰模式或者AOP技术来捕获返回值前后的状态变化。下面是一个简单的例子展示如果捕捉到Response Headers进而保存新的Session Tokens: ```java import feign.Response; import org.springframework.stereotype.Component; @Component public class ResponseHandler { public void handle(Response response){ // 获取所有的headers Map<String, Collection<String>> headers = response.headers(); // 查找是否有新产生的token if(headers.containsKey("New-Authorization")){ List<String> tokens = headers.get("New-Authorization"); if(!tokens.isEmpty()){ String newAccessToken = tokens.iterator().next(); // 更新本地缓存或者其他存储位置的新token值 updateLocalCache(newAccessToken); } } } private void updateLocalCache(String newAccessToken){ System.out.println("Updated access token to "+newAccessToken); } } ``` 此部分代码说明了当接收到服务器回应时,怎样检查是否存在更新版的身份验证令牌,并相应地刷新应用程序内部维护的状态副本[^1]。 #### 整合进业务流程 最后一步是要确保每次完成远程调用之后都会触发这个处理器函数执行。这可能涉及到修改现有的服务层架构设计或者是引入额外的技术手段像切面编程(AOP)等。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值