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

Feign 请求拦截器和日志的更多相关文章

  1. 实现Feign请求拦截器,对请求header等参数进行转发

    参考:Feign传递请求头信息(Finchley版本) 问题:通过Feign远程调用服务,无法传递header参数. 解决方式:实现RequestInterceptor接口(对所有的Feign请求进行 ...

  2. Vue添加请求拦截器

    一.现象 统一处理错误及配置请求信息 二.解决 1.安装 axios  , 命令: npm install axios --save-dev 2.在根目录的config目录下新建文件 axios.js ...

  3. 细说vue axios登录请求拦截器

    当我们在做接口请求时,比如判断登录超时时候,通常是接口返回一个特定的错误码,那如果我们每个接口都去判断一个耗时耗力,这个时候我们可以用拦截器去进行统一的http请求拦截. 1.安装配置axios cn ...

  4. vue 路由拦截器和请求拦截器

    路由拦截器 已路由为导向 router.beforeEach((to,from,next)=>{ if(to.path=='/login' || localStorage.getItem('to ...

  5. vue+axois 封装请求+拦截器(请求锁+统一错误)

     需求 封装常用请求 拦截器-请求锁 统一处理错误码 一.封装常用的请求 解决痛点:不要每一个模块的api都还要写get,post,patch请求方法.直接将这些常用的方法封装好. 解决方案:写一个类 ...

  6. http request 请求拦截器,有token值则配置上token值

    // http request 请求拦截器,有token值则配置上token值 axios.interceptors.request.use( config => { if (token) { ...

  7. axios源码解析 - 请求拦截器

    axios请求拦截器,也就是在请求发送之前执行自定义的函数. axios源码版本 - ^0.27.2 (源码是精简版) 平时在业务中会这样去写请求拦截器,代码如下: // 创建一个新的实例 var s ...

  8. struts2-权限拦截器、日志拦截器、execAndWait(进度条)拦截器配置

    1.权限拦截器 package login; import javax.servlet.http.HttpServletResponse; import org.apache.struts2.Serv ...

  9. 使用spring拦截器实现日志管理

    使用HandlerInterceptor拦截器,可以拦截请求,实现通用的日志管理操作 一.添加拦截器类 在"src/main/java"代码文件夹的"org.xs.dem ...

随机推荐

  1. springboot区分开发、测试、生产多环境的应用配置

    转:https://blog.csdn.net/daguairen/article/details/79236885 springboot区分开发.测试.生产多环境的应用配置(一) Spring可使用 ...

  2. react native 之 Android物理返回键

    基本用法 根据文档,安卓back键的处理主要就是一个事件监听: BackAndroid.addEventListener('hardwareBackPress', this.onBackPressed ...

  3. 河工大第十届ACM省赛随笔

    比赛成果达到了预期目标,不过还是很遗憾没有更进一步,刚到河工大的时候就想吐槽,拥挤的机房,难受的键盘鼠标,还有规定食堂的,饭票.一切都和河大比赛是给我的感觉不一样,再加上热身赛的那天我背着一大包东西, ...

  4. Golang游戏服务器与skynet的个人直观比较

    我对和GOLANG写MMO服务器的一些遐想: 1.沙盒(隔离性) SKYNET:原生LUA STATE作为沙盒, 进行服务器间隔离安全性高: 服务可以很容易的配置到不同节点之上. GO:估计用RECO ...

  5. 对jQuery ajax的认识

    1.ajax() 方法通过 HTTP 请求加载远程数据. 2.该方法是 jQuery 底层 AJAX 实现.简单易用的高层实现见 $.get, $.post 等.$.ajax() 返回其创建的 XML ...

  6. Gauss error function

    0. error function erf(x)=1π∫−xxe−t2dt" role="presentation">erf(x)=1π−−√∫x−xe−t2dte ...

  7. iOS 静态库代码混淆方案

    基于开源 Obfuscator-LLVM方案 下载安装最新版本 Obfuscator-LLVM,目前3.6.1 $ git clone -b llvm-3.6.1 https://github.com ...

  8. Seaweedfs-启动脚本

    #!/bin/bash if [ ! -e /sunlight/shell/main.sh ];then echo " [ Error ] file /sunlight/shell/main ...

  9. php-fpm的pool池子、php慢日志记录、open_basedir、php-fpm进程管理

    1.php-fpm的poo池子:目的:可以让不同的网站,对于不同的php解析,可以把不同的网站解析区分开.编辑:vim /usr/local/php5-fpm/etc/php-fpm.conf加入: ...

  10. 服务器cpu负载过高问题排查

    https://blog.csdn.net/MrZhangXL/article/details/77711996 第一步 :执行top命令,查出当前机器线程情况 top - 09:14:36 up 1 ...