1,Feign远程调用丢失请求头
根据图中的流程,Feign远程调用丢失cookie的原因可以分析如下:
-
浏览器发送请求:浏览器向
order服务
发送请求,请求头中自动携带了cookie。 -
Feign远程调用:
order服务
通过Feign远程调用cart服务
。 -
创建新request:在Feign远程调用过程中,创建了一个新的request,这个新request没有任何请求头,没把浏览器携带的请求头复制到新的请求头中。
-
丢失cookie:由于新request没有携带任何请求头,因此丢失了原本在浏览器请求中自动携带的cookie。
-
cart服务认为未登录:
cart服务
接收到的请求没有请求头,因此认为用户未登录。
Feign远程调用过程中,由于创建了一个新的request,这个新request没有携带任何请求头,包括原本在浏览器请求中自动携带的cookie,导致cart服务
接收到的请求没有cookie,从而认为用户未登录。
2,解决方案
这段代码定义了一个名为GuliFeignConfig
的配置类,该类中包含一个@Bean
注解的方法requestInterceptor
,用于创建和配置一个RequestInterceptor
实例。RequestInterceptor
是一个接口,用于拦截Feign客户端的请求,并在请求发送之前对其进行修改。
解释说明
-
创建拦截器实例:
@Bean("requestInterceptor") public RequestInterceptor requestInterceptor() { // 创建RequestInterceptor实例 RequestInterceptor requestInterceptor = new RequestInterceptor() { // 实现apply方法 @Override public void apply(RequestTemplate template) { // 在这里添加自定义的逻辑 } }; return requestInterceptor; }
这段代码创建了一个
RequestInterceptor
的实例,并实现了apply
方法。apply
方法会在Feign客户端发送请求之前被调用,用于修改请求模板。 -
获取请求头:
ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); if (requestAttributes != null) { HttpServletRequest request = requestAttributes.getRequest(); if (request != null) { String cookie = request.getHeader("Cookie"); template.header("Cookie", cookie); } }
在
apply
方法中,首先通过RequestContextHolder.getRequestAttributes()
获取当前请求的ServletRequestAttributes
。然后,从ServletRequestAttributes
中获取HttpServletRequest
对象,从而获取到当前请求的请求头。最后,从请求头中获取Cookie
值,并将其添加到RequestTemplate
的请求头中。
如何起作用
当Feign客户端发送请求时,RequestInterceptor
的apply
方法会被调用。在这个方法中,通过RequestContextHolder
获取到当前请求的HttpServletRequest
对象,从而获取到请求头中的Cookie
值。然后,将这个Cookie
值添加到RequestTemplate
的请求头中,确保Feign远程调用时携带了这个Cookie
。
通过这种方式,即使在Feign远程调用过程中创建了新的请求,这个新的请求也会携带原来的Cookie
,从而解决了Feign远程调用丢失cookie的问题。