博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Feign 请求拦截器和日志
阅读量:6713 次
发布时间:2019-06-25

本文共 1878 字,大约阅读时间需要 6 分钟。

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/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 数据

转载地址:http://iiilo.baihongyu.com/

你可能感兴趣的文章
关闭ecplise自动编译!!
查看>>
LinkedList
查看>>
C++对象的内存分析(6)
查看>>
我的友情链接
查看>>
认识测试估算
查看>>
win32 的DLL中创建windows窗口
查看>>
cobbler get-loaders 错误解决方法
查看>>
Android UI开发第二篇——多级列表(ExpandableListView)
查看>>
CC***原理
查看>>
库(静态库和动态库)
查看>>
visualSVN(win)迁移到subvision(linux)
查看>>
4.91Python数据类型之(6)元组
查看>>
我的友情链接
查看>>
联想G40进入BIOS
查看>>
修改oracle用户id
查看>>
12个flex常用功能代码
查看>>
无法启动OracleDBConsoleorcl服务
查看>>
我的友情链接
查看>>
log4j与commons-logging,slf4j的关系
查看>>
Mysql、MSSQL选择和比较
查看>>