解决feign请求头叠加问题
This commit is contained in:
@ -76,18 +76,20 @@ public class FeignConfig implements RequestInterceptor {
|
|||||||
*/
|
*/
|
||||||
private void injectToken(RequestTemplate template, ServletRequestAttributes attributes) {
|
private void injectToken(RequestTemplate template, ServletRequestAttributes attributes) {
|
||||||
final String header = attributes.getRequest().getHeader(AUTHORIZATION_HEADER);// 提取request头信息
|
final String header = attributes.getRequest().getHeader(AUTHORIZATION_HEADER);// 提取request头信息
|
||||||
|
// 移除已存的头信息
|
||||||
|
template.removeHeader(AUTHORIZATION_HEADER);
|
||||||
|
|
||||||
// 检查请求头是否包含 Bearer 前缀
|
// 检查请求头是否包含 Bearer 前缀
|
||||||
if (StringUtils.startsWith(header, TOKEN_PREFIX)) {
|
if (StringUtils.startsWith(header, TOKEN_PREFIX)) {
|
||||||
log.info("FeignConfig request header {from header}", AUTHORIZATION_HEADER, header);
|
log.info("FeignConfig request header (from header) {} {}", AUTHORIZATION_HEADER, header);
|
||||||
template.header(AUTHORIZATION_HEADER, header);
|
template.header(AUTHORIZATION_HEADER, header);
|
||||||
} else {// 检查cookie
|
} else {// 检查cookie
|
||||||
Optional.ofNullable(attributes.getRequest().getCookies()).ifPresent(cookies -> {
|
Optional.ofNullable(attributes.getRequest().getCookies()).ifPresent(cookies -> {
|
||||||
Stream.of(cookies).filter(item -> StringUtils.equals(item.getName(), COOKIE_TOKEN_CODE)).findFirst()
|
Stream.of(cookies).filter(item -> StringUtils.equals(item.getName(), COOKIE_TOKEN_CODE)).findFirst()
|
||||||
.ifPresent(token -> {
|
.ifPresent(token -> {
|
||||||
String authToken = token.getValue();
|
String authToken = token.getValue();
|
||||||
log.info("FeignConfig request header (from cookie): {} {}",
|
log.info("FeignConfig request header (from cookie): {}",
|
||||||
String.format("%s%s", AUTHORIZATION_HEADER, TOKEN_PREFIX, authToken));
|
String.format("%s %s%s", AUTHORIZATION_HEADER, TOKEN_PREFIX, authToken));
|
||||||
template.header(AUTHORIZATION_HEADER, String.format("%s%s", TOKEN_PREFIX, authToken));
|
template.header(AUTHORIZATION_HEADER, String.format("%s%s", TOKEN_PREFIX, authToken));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user