问题描述
在公司一次接口调用的时候,由于所有的接口都需要在请求头上设置token来验证身份,所以我从本服务调用远程服务的时候使用了feign来调用,但是出现了一个很致命的问题,由于我用了线程池,导致request被销毁,在子线程中无法访问主线程的request(其实就算能访问到也被销毁了),所以调用的时候显示未登录。
同时我也使用拦截器做了处理,但是由于request已经不是主线程那个request,所以在用线程池异步调用远程接口时,根本无法使用。
@Configuration
public class FeignConfiguration implements RequestInterceptor {
@Override
public void apply(RequestTemplate requestTemplate) {
HttpServletRequest request = SpringContextUtils.getHttpServletRequest();
Enumeration<String> headerNames = request.getHeaderNames();
if (headerNames != null) {
while (headerNames.hasMoreElements()) {
String name = headerNames.nextElement();
String values = request.getHeader(name);
requestTemplate.header(name, values);
}
}
}
}
解决思路
首先由于request已经被销毁,那么我就只能先把我所需要的token保存下来,将token传入进来之后,事情就好办了许多,我们在fegin调用的时候,会使用feginClient将接口暴露到我们的代码里,这时候只需要在方法的参数前面上使用@RequestHeader就可以将我们所需要的token设置到header里
@FeignClient(name = "test", url = "${test-url}")
@Component
public interface TestFegin {
@PostMapping(value = "/auth/oauth/token")
JSONObject getList(@RequestHeader("token") String token,
@RequestParam("username") String username,
@RequestParam("password") String password);
}
这里感谢两篇博客提供的解决思路