修改了 feign config, 调整了request header格式

This commit is contained in:
ajaxfan
2020-12-30 15:53:26 +08:00
parent 0f2577195b
commit 0fa0e73342

View File

@ -1,12 +1,12 @@
package com.chinaunicom.mall.ebtp.common.config; package com.chinaunicom.mall.ebtp.common.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.context.SecurityContext;
import org.springframework.security.core.context.SecurityContextHolder;
import feign.RequestInterceptor; import feign.RequestInterceptor;
import feign.RequestTemplate; import feign.RequestTemplate;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
/** /**
* fegin调用时 header中添加JwtToken * fegin调用时 header中添加JwtToken
@ -14,14 +14,24 @@ import javax.servlet.http.HttpServletRequest;
@Configuration @Configuration
public class FeignConfig implements RequestInterceptor { public class FeignConfig implements RequestInterceptor {
@Override private final String AUTHORIZATION_HEADER = "Authorization";
public void apply(RequestTemplate template) { private final String BEARER_TOKEN_TYPE = "Bearer";
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
if (null != attributes) { @Override
HttpServletRequest request = attributes.getRequest(); public void apply(RequestTemplate template) {
String token = request.getHeader("JwtToken"); // ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
template.header("JwtToken", token); // if (null != attributes) {
} // HttpServletRequest request = attributes.getRequest();
} // String token = request.getHeader("JwtToken");
// template.header("JwtToken", token);
// }
SecurityContext securityContext = SecurityContextHolder.getContext();
Authentication authentication = securityContext.getAuthentication();
if (authentication != null && authentication.getCredentials() instanceof String) {
String token = (String) authentication.getCredentials();
template.header(AUTHORIZATION_HEADER, String.format("%s %s", BEARER_TOKEN_TYPE, token));
}
}
} }