先说一下业务场景,一共有三个服务:
1 : 公共平台是基于微服务开发的;
2 : 项目A是基于微服务开发的;
3 : 项目B是老的项目;
我们在做的项目A登录的时候请求公共平台(xxxxCenter),获取token,用token去调用公共平台的相关接口;
调用项目B的接口,需要调用登录项目B的接口,重新获取token,再去调用接口;
在对接的时候,调用公共平台和项目B相关接口的时候,需要携带不同的token;
调用公共平台的接口不是我完成的,我只负责项目B的接口对接,
feign调用带token的处理方式网上挺多的,我采用的是拦截器的方法(Feign有提供一个接口RequestInterceptor),具体可以参考 : 添加链接描述
造成这个问题的原因网上有很多;
1.有的是路径错误或者是参数错误 : 添加链接描述
2.这个大哥提出了几种错误原因以及解决方式 : 添加链接描述
我的原因经过排查是header中信息过长,打出堆栈信息可以看出,header中的Authorization的值有两个:
出现两个token的原因:
因为有两个拦截器,一个是公共平台封装的一个注解引入了拦截器,一个是我自己写的拦截器配置类,都是通过RequestInterceptor实现的;
第一个是请求项目A的token,第二个是我写的拦截器请求项目B接口之前塞进去的token;
RequestTemplate的header是header(String name, String… values),是key,values的结构
找到原因就很好解决了,我直接干掉了公共平台的注解,自己重新写了拦截器的配置类,对接口路径进行区分就行了.