使用场景:
在门户系统,需要通过传递token来确认用户是否登录,所以各个系统间调用时需传递header里面存储的token值
1.通过 @RequestHeader(name = “headerName”) 来传递

2.通过实现RequestInterceptor来实现
import feign.RequestInterceptor;
import feign.RequestTemplate;
import lombok.extern.slf4j.Slf4j;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
import java.util.Enumeration;
/**
* 解决feign不能传HttpServletRequest
*/
@Component
@Slf4j
public class FeignConfiguration {
@Bean
public RequestInterceptor requestInterceptor() {
return new RequestInterceptor() {
@Override
public void apply(RequestTemplate template) {
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
Enumeration<String> headerNames = request.getHeaderNames();
if (headerNames != null) {
while (headerNames.hasMoreElements()) {
String name = headerNames.nextElement();
String values = request.getHeader(name);
template.header(name, values);
}
}
Enumeration<String> bodyNames = request.getParameterNames();
StringBuffer body =new StringBuffer();
if (bodyNames != null) {
while (bodyNames.hasMoreElements()) {
String name = bodyNames.nextElement();
String values = request.getParameter(name);
body.append(name).append("=").append(values).append("&");
}
}
if(body.length()!=0) {
body.deleteCharAt(body.length()-1);
template.body(body.toString());
log.info("feign interceptor body:{}",body.toString());
}
}
};
}
}

该博客介绍了在门户系统中如何利用Feign实现请求拦截,确保在各个系统间调用时能够正确传递header中的token值。通过@RequestHeader注解和实现RequestInterceptor接口两种方式详细阐述了传递过程,确保用户登录状态的验证。
7304

被折叠的 条评论
为什么被折叠?



