spring cloud 微服务调用微服务未认证解决方案(Feign)

逃离我推掉我的手 2022-02-22 02:27 995阅读 0赞

响应异常:

  1. {"error":"unauthorized","error_description":"Full authentication is required to access thisresource"}

当实现了用户携带身份令牌访问微服务之后,

微服务直接的访问调用就会抛出未授权的异常,,解决方案 服务直接调用时携带令牌

Feign 拦截器

添加依赖:

  1. <dependency>
  2. <groupId>org.springframework.cloud</groupId>
  3. <artifactId>spring-cloud-starter-openfeign</artifactId>
  4. <version>1.4.4.RELEASE</version>
  5. </dependency>

创建拦截器

  1. import feign.RequestInterceptor;
  2. import feign.RequestTemplate;
  3. import org.springframework.web.context.request.RequestContextHolder;
  4. import org.springframework.web.context.request.ServletRequestAttributes;
  5. import javax.servlet.http.HttpServletRequest;
  6. import java.util.Enumeration;
  7. public class FeignClientInterceptor implements RequestInterceptor {
  8. @Override
  9. public void apply(RequestTemplate requestTemplate) {
  10. //拦截器
  11. //使用RequestContextHolder工具获取request相关变量
  12. try {
  13. ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
  14. if (attributes != null){
  15. // 取出request
  16. HttpServletRequest request = attributes.getRequest();
  17. // 取出所有请求头
  18. Enumeration<String> headerNames = request.getHeaderNames();
  19. while (headerNames.hasMoreElements()){
  20. String name = headerNames.nextElement(); // key
  21. String value = request.getHeader(name); //value
  22. if(name.equals("authorization")){ //auoth2 认证请求头
  23. //System.out.println("name="+name+"values="+values);
  24. requestTemplate.header(name, value);
  25. }
  26. }
  27. }
  28. }catch (Exception e){
  29. }
  30. }
  31. }

使用feign

在 springboot 启动类中配置feign拦截器

  1. // 配置feign拦截器
  2. @Bean
  3. public FeignClientInterceptor feignClientInterceptor(){
  4. return new FeignClientInterceptor();
  5. }

然后就行了

发表评论

表情:
评论列表 (有 0 条评论,995人围观)

还没有评论,来说两句吧...

相关阅读