Feign拦截器和解码器
一、业务需求
在Spring Cloud的项目中,A服务使用Feign调用B服务的某个接口,如果需要传递全局认证token或参数,在方法参数里面加相应字段的方式显然是不可取的。
首先想到的是AOP方式,使用切面拦截Feign方法,在AOP切面里面向方法参数里面添加数据,Feign方法执行完成之后,从响应对象里面获取返回的数据,这样的方式可以解决数据的传递和接收,但也必将需要方法参数和响应对象的支持,与业务耦合,并不是合理的架构实现方案。
如果有某种机制可以拦截到Feign的请求对象和响应对象,便可以获取到请求头和响应头,就可以使用请求头和响应头来传递数据。
经过一番调查,了解到Feign的RequestInterceptor可以拦截到Feign请求,可以获取到请求对象和请求头,但是RequestInterceptor无法处理响应。
于是又进行调查,得知解码器Decoder是对响应进行解码的组件,可以获取到响应对象和响应头。
在调查过程中,还有另外的收获:FeignClientsConfiguration类。
二、FeignClientsConfiguration类
Feign默认配置类是FeignClientsConfiguration类,该类定义了Feign默认的编码器、解码器、所使用的契约等。
Spring Cloud允许通过注解@FeignClient的configuration属性自定义Feign配置,自定义配置的优先级比FeignClientsConfiguration要高。
这个类的核心代码如下:
1 @Configuration
2 public class FeignClientsConfiguration {
3
4 @Autowired
5 private ObjectFactory<HttpMessageConverters> messageConverters;
6
7 @Autowired(required = false)
8 private List<AnnotatedParameterProcessor> parameterProcessors = new ArrayList<>();
9
10 @Autowired(required = false)
11 private List<FeignFormatterRegistrar> feignFormatterRegistrars = new ArrayList<>();
12
13 @Autowired(required = false)
14 private Logger logger;
15
16 @Bean
17 @ConditionalOnMissingBean
18 public Decoder feignDecoder() {
19 return new OptionalDecoder(new ResponseEntityDecoder(new SpringDecoder(this.messageConverters)));
20 }
21
22 @Bean
23 @ConditionalOnMissingBean
24 @ConditionalOnMissingClass("org.springframework.data.domain.Pageable")
25 public Encoder feignEncoder() {
26 return new SpringEncoder(this.messageConverters);
27 }
28
29 @Bean
30 @ConditionalOnMissingBean
31 public Contract feignContract(ConversionService feignConversionService) {
32 return new SpringMvcContract(this.parameterProcessors, feignConversionService);
33 }
34
35 @Bean
36 @Scope("prototype")
37 @ConditionalOnMissingBean
38 public Feign.Builder feignBuilder(Retryer retryer) {
39 return Feign.builder().retryer(retryer);
40 }
41 }
三、Feign请求拦截器
参考FeignClientsConfiguration类,我们可以编写一个configuration类,注入自定义的RequestInterceptor实现类对象,在apply(RequestTemplate requestTemplate)方法中获取到请求RestTemplate对象,使用RequestTemplate对象设置请求参数、添加请求头。
示例如下:
1 @Configuration
2 public class MyConfig {
3 @Bean("myInterceptor")
4 public RequestInterceptor getRequestInterceptor() {
5 return new MyClientInterceptor();
6 }
7 }
MyClientInterceptor类:
1 class MyClientInterceptor implements RequestInterceptor {
2 @Override
3 public void apply(RequestTemplate requestTemplate) {
4 requestTemplate.query("name", "Allen");
5 requestTemplate
6 .header("token", "token")
7 .header("id", id);
8 }
9 }
四、Feign解码器
1、解码器概述
Feign解码器负责对响应进行解码,返回符合Feign接口需求的对象。
我们可以参考FeignClientsConfiguration类中的方式编写和注入自定义的解码器。
1 @Bean
2 @ConditionalOnMissingBean
3 public Decoder feignDecoder() {
4 return new OptionalDecoder(
5 new ResponseEntityDecoder(new SpringDecoder(this.messageConverters)));
6 }
2、继承SpringDecoder自定义解码器
1 class TraceDecoder extends SpringDecoder {
2
3 TraceDecoder(ObjectFactory<HttpMessageConverters> messageConverters) {
4 super(messageConverters);
5 }
6
7 @Override
8 public Object decode(Response response, Type type) throws IOException, FeignException {
9
10 // 这里可以从response对象里面获取响应头和响应体
11
12 // 获取响应头
13 Map<String, Collection<String>> headers = response.headers();
14
15 return super.decode(response, type);
16 }
17 }
3、注入自定义解码器
feignDecoder()方法完全参考了FeignClientsConfiguration类的写法。
1 @Slf4j
2 @Configuration
3 @ConditionalOnClass({Feign.class})
4 @AutoConfigureBefore(FeignAutoConfiguration.class)
5 public class CommonLogFeignConfig {
6
7 @Autowired
8 private ObjectFactory<HttpMessageConverters> messageConverters;
9
10 @Bean
11 public Decoder feignDecoder() {
12 return new OptionalDecoder(new ResponseEntityDecoder(new TraceDecoder(this.messageConverters)));
13 }
14 }
Feign拦截器和解码器的更多相关文章
- 阶段5 3.微服务项目【学成在线】_day18 用户授权_19-微服务之间认证-Feign 拦截器
4.2 Feign 拦截器 4.2.1 定义Feign拦截器 微服务之间使用feign进行远程调用,采用feign拦截器实现远程调用携带JWT. 在common工程添加依赖: <dependen ...
- 自定义Feign拦截器
简介 Feign的拦截器RequestInterceptor SpringCloud的微服务使用Feign进行服务间调用的时候可以使用RequestInterceptor统一拦截请求来完成设置head ...
- Feign拦截器应用 (F版)
Spring Cloud 为开发者提供了在分布式系统中的一些常用的组件(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,决策竞选,分布式会话集群状态).使用Sprin ...
- Feign 请求拦截器和日志
Feign 支持请求拦截器,在发送请求前,可以对发送的模板进行操作,例如设置请求头等属性,自定请求拦截器需要实现 feign.RequestInterceptor 接口,该接口的方法 apply 有参 ...
- 实现Feign请求拦截器,对请求header等参数进行转发
参考:Feign传递请求头信息(Finchley版本) 问题:通过Feign远程调用服务,无法传递header参数. 解决方式:实现RequestInterceptor接口(对所有的Feign请求进行 ...
- Feign 自定义编码器、解码器和客户端,Feign 转发请求头(header参数)、Feign输出Info级别日志
Feign 的编码器.解码器和客户端都是支持自定义扩展,可以对请求以及结果和发起请求的过程进行自定义实现,Feign 默认支持 JSON 格式的编码器和解码器,如果希望支持其他的或者自定义格式就需要编 ...
- Mina源码阅读笔记(七)—Mina的拦截器FilterChain
Filter我们很熟悉,在Mina中,filter chain的用法也类似于Servlet的filters,这种拦截器的设计思想能够狠轻松的帮助我们实现对资源的统一处理.我们先大致连接下mina中的f ...
- 6. ModelDriven拦截器、Preparable 拦截器
1. 问题 Struts2 的 Action 我们将它定义为一个控制器,但是由于在 Action 中也可以来编写一些业务逻辑,也有人会在 Action 输入业务逻辑层. 但是在企业开发中,我们一般会将 ...
- springmvc的拦截器
什么是拦截器 java里的拦截器是动态拦截action调用的对象.它提供了一种机制可以使 ...
- Struts的拦截器
Struts的拦截器 1.什么是拦截器 Struts的拦截器和Servlet过滤器类似,在执行Action的execute方法之前,Struts会首先执行Struts.xml中引用的拦截器,在执行完所 ...
随机推荐
- DFS遍历图(链式邻接表实现)
1 #include<iostream> 2 #include<string.h> 3 #include<stdlib.h> 4 #include<stdio ...
- 研发提效必备技能:手把手教你基于Docker搭建Maven私服仓库
沉淀,成长,突破,帮助他人,成就自我. 大家好,我是冰河~~ 在研发的过程中,很多企业都会针对自身业务特点来定制研发一些工具类库,但是这些工具类库又不会对外公开,那如何在组织内部共享这些类库呢?一种很 ...
- flask请求钩子(就是django的中间件)
flask中的请求钩子就是域django的中间件类似,作用都是用于在请求前.后.响应前.后进行一些hook操作. 请求钩子装饰器 @app.before_request # 请求前会调用,一般可以用来 ...
- vscode快速配置汇编环境
微机原理的课程需要,简单快速记录环境的搭建 找到并安装插件masm. MASM/TASM的汇编工具默认是tasm这样就无法在vscode终端进行debug,打开插件设置如下修改: 测试代码实现小写字母 ...
- .NET技术分享日活动-202107
2021年7月3日下午,个人组织举办了山东地区的第二次山东.NET技术分享日活动.围绕互联网技术.大数据.机器学习.业务实践等方向进行创新技术的实践分享. 本次技术分享日活动面向了山东地区广大的.NE ...
- 用GaussDB合理管控数据资源的几点心得
一.摘要 项目交付中可能会遇到同时包含核心交易(OLTP)和报表分析(OLAP)的混合业务场景,其中报表分析类业务复杂度高,消耗大量系统资源,但实时性要求较低,而核心交易类业务并发较大,多为简单事务处 ...
- 手把手带你写Node.JS版本小游戏
摘要:今天就利用Node.JS为大家带来简单有趣的的剪刀石头布的小游戏. JavaScript的出现催动了前端开发的萌芽,前后端分离促进了Vue.React等开发框架的发展,Weex.React-Na ...
- 华为云发布CodeArts Req需求管理工具,让需求管理化繁为简
摘要:华为云正式发布CodeArts Req,这是一款自主研发的软件研发管理与团队协作工具,旨在助力企业大规模研发转型成功,释放组织生产力. 本文分享自华为云社区<华为云发布CodeArts R ...
- LiteOS内核源码分析:静态内存Static Memory
摘要:本文带领大家一起剖析了LiteOS静态内存模块的源代码,包含静态内存的结构体.静态内存池初始化.静态内存申请.释放.清除内容等. 内存管理模块管理系统的内存资源,它是操作系统的核心模块之一,主要 ...
- LAS Spark+云原生:数据分析全新解决方案
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 随着数据规模的迅速增长和数据处理需求的不断演进,云原生架构和湖仓分析成为了现代数据处理的重要趋势.在这个数字化时代 ...