FeignClient调用接口400异常

2 篇文章 0 订阅
2 篇文章 0 订阅

排查结果

feign调用时,会将springWeb的org.springframework.web.context.request.RequestContextHolder#requestAttributesHolder中所有消息头带上。其中有认证消息头信息【authorization】,同时feign调用的接口也需要认证,通过拦截器增加了消息头【Authorization】,导致两者冲突,产生问题。

排查过程

  1. 发现网站过来的请求调用下游接口400,跑单测时可以正常,需要看看两者的区别
  2. 将接口调用信息全部打印,需要两行配置
feign.client.config.xxxClient.loggerLevel=FULL
logging.level.XXXClient=DEBUG
  1. 两者调用日志对比,发现,网站过来的请求多了好多消息头,那应该是这里的问题。查看中发现有【authorization】这个,需要进一步排查
  2. 我们使用postman调用下游接口,正常是需要【Authorization】消息头。但是我们在消息头中再增加【authorization】以后,接口就400了,原因定位

源码分析

  1. org.springframework.web.context.request.RequestContextHolder#requestAttributesHolder,spring的rest接口调用时会将头信息和属性信息放到这个ThreadLocal变量
  2. 我们项目里有个全局拦截器,将上面RequestContextHolder中所有头信息加入到restTemplate了,包含【authorization】,导致问题发生
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值