好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

使用Feign调用时添加验证信息token到请求头方式

Feign调用添加验证信息token到请求头

1、这是最简单的一个方法

但是需要对每个调用都一一添加,就是使用@RequestHeader注解添加参数到请求头中去

?

1

2

3

4

5

6

7

8

9

@FeignClient (name = "capability-register" , fallback = ApiServiceClientFallBack. class )

public interface ApiServiceClient { 

    @GetMapping ( "/apiDebug/" )

    Result debug( @RequestParam ( "url" ) String path,

                  @RequestParam ( "param" ) String param,

                  @RequestParam ( "method" ) String method,

                  @RequestParam ( "appKey" ) String appKey,

                  @RequestHeader (name = "Token" ,required = true ) String Token);

}

这里需要注意,其他几个参数都是调用debug接口需要的参数,使用此接口时,直接获取验证信息放进token中,就可以了

2、这个方法是网上大多数人的用法

但是我看到一个大神的博客,说是这种方法有点不好,然后大神自定义了一个Hystrix的策略,这个第三种方法再讲

这种方法是对所有的feign调用统一设置请求头

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

package com.hiynn.provider.configuration; 

import feign.RequestInterceptor;

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;

 

/**

  * @author lidai

  * @date 2019/2/27 16:14

  * <p>

  * Feign调用的时候添加请求头Token

  */

@Configuration

public class FeignConfiguration implements RequestInterceptor {

 

    @Override

    public void apply(RequestTemplate requestTemplate) {

        ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();

        HttpServletRequest request = attributes.getRequest();

        requestTemplate.header( "Token" , request.getHeader( "Token" ));

    }

}

有了configuration之后还需要再feign添加configuration属性

?

1

2

3

4

5

6

7

8

9

@FeignClient (name = "capability-register" , fallback = ApiServiceClientFallBack. class ,configuration = FeignConfiguration. class )

public interface ApiServiceClient {

 

    @GetMapping ( "/apiDebug/" )

    Result debug( @RequestParam ( "url" ) String path,

                  @RequestParam ( "param" ) String param,

                  @RequestParam ( "method" ) String method,

                  @RequestParam ( "appKey" ) String appKey);

}

到这里的时候,如果你debug的话,会发现FeignConfiguration中的attributes获取不到,需要再配置文件中添加如下配置就可以了

?

1

2

3

4

5

6

hystrix:

   command:

    default:

      execution:

        isolation:

          strategy: SEMAPHORE

3、第三种方法就是大神的方法了

和第二种方法的区别就是不需要添加配置文件,但是FeignConfiguration这个还是要的,不需要加配置文件就加一个自定义策略

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

package com.hiynn.provider.configuration; 

import com.netflix.hystrix.HystrixThreadPoolKey;

import com.netflix.hystrix.HystrixThreadPoolProperties;

import com.netflix.hystrix.strategy.HystrixPlugins;

import com.netflix.hystrix.strategy.concurrency.HystrixConcurrencyStrategy;

import com.netflix.hystrix.strategy.concurrency.HystrixRequestVariable;

import com.netflix.hystrix.strategy.concurrency.HystrixRequestVariableLifecycle;

import com.netflix.hystrix.strategy.eventnotifier.HystrixEventNotifier;

import com.netflix.hystrix.strategy.executionhook.HystrixCommandExecutionHook;

import com.netflix.hystrix.strategy.metrics.HystrixMetricsPublisher;

import com.netflix.hystrix.strategy.properties.HystrixPropertiesStrategy;

import com.netflix.hystrix.strategy.properties.HystrixProperty;

import lombok.extern.slf4j.Slf4j;

import org.springframework.context.annotation.Configuration;

import org.springframework.web.context.request.RequestAttributes;

import org.springframework.web.context.request.RequestContextHolder;

 

import java.util.concurrent.BlockingQueue;

import java.util.concurrent.Callable;

import java.util.concurrent.ThreadPoolExecutor;

import java.util.concurrent.TimeUnit;

 

/**

  * @author lidai

  * @date 2019/3/18 10:09

  */

@Slf4j

@Configuration

public class FeignHystrixConcurrencyStrategy extends HystrixConcurrencyStrategy {

    private HystrixConcurrencyStrategy delegate;

 

    public FeignHystrixConcurrencyStrategy() {

        try {

            this .delegate = HystrixPlugins.getInstance().getConcurrencyStrategy();

            if ( this .delegate instanceof FeignHystrixConcurrencyStrategy) {

                // Welcome to singleton hell...

                return ;

            }

            HystrixCommandExecutionHook commandExecutionHook =

                    HystrixPlugins.getInstance().getCommandExecutionHook();

            HystrixEventNotifier eventNotifier = HystrixPlugins.getInstance().getEventNotifier();

            HystrixMetricsPublisher metricsPublisher = HystrixPlugins.getInstance().getMetricsPublisher();

            HystrixPropertiesStrategy propertiesStrategy =

                    HystrixPlugins.getInstance().getPropertiesStrategy();

            this .logCurrentStateOfHystrixPlugins(eventNotifier, metricsPublisher, propertiesStrategy);

            HystrixPlugins.reset();

            HystrixPlugins.getInstance().registerConcurrencyStrategy( this );

            HystrixPlugins.getInstance().registerCommandExecutionHook(commandExecutionHook);

            HystrixPlugins.getInstance().registerEventNotifier(eventNotifier);

            HystrixPlugins.getInstance().registerMetricsPublisher(metricsPublisher);

            HystrixPlugins.getInstance().registerPropertiesStrategy(propertiesStrategy);

        } catch (Exception e) {

            log.error( "Failed to register Sleuth Hystrix Concurrency Strategy" , e);

        }

    }

 

    private void logCurrentStateOfHystrixPlugins(HystrixEventNotifier eventNotifier,

                                                  HystrixMetricsPublisher metricsPublisher, HystrixPropertiesStrategy propertiesStrategy) {

        if (log.isDebugEnabled()) {

            log.debug( "Current Hystrix plugins configuration is [" + "concurrencyStrategy ["

                    + this .delegate + "]," + "eventNotifier [" + eventNotifier + "]," + "metricPublisher ["

                    + metricsPublisher + "]," + "propertiesStrategy [" + propertiesStrategy + "]," + "]" );

            log.debug( "Registering Sleuth Hystrix Concurrency Strategy." );

        }

    }

 

    @Override

    public <T> Callable<T> wrapCallable(Callable<T> callable) {

        RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();

        return new WrappedCallable<>(callable, requestAttributes);

    }

 

    @Override

    public ThreadPoolExecutor getThreadPool(HystrixThreadPoolKey threadPoolKey,

                                            HystrixProperty<Integer> corePoolSize, HystrixProperty<Integer> maximumPoolSize,

                                            HystrixProperty<Integer> keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue) {

        return this .delegate.getThreadPool(threadPoolKey, corePoolSize, maximumPoolSize, keepAliveTime,

                unit, workQueue);

    }

 

    @Override

    public ThreadPoolExecutor getThreadPool(HystrixThreadPoolKey threadPoolKey,

                                            HystrixThreadPoolProperties threadPoolProperties) {

        return this .delegate.getThreadPool(threadPoolKey, threadPoolProperties);

    }

 

    @Override

    public BlockingQueue<Runnable> getBlockingQueue( int maxQueueSize) {

        return this .delegate.getBlockingQueue(maxQueueSize);

    }

 

    @Override

    public <T> HystrixRequestVariable<T> getRequestVariable(HystrixRequestVariableLifecycle<T> rv) {

        return this .delegate.getRequestVariable(rv);

    }

 

    static class WrappedCallable<T> implements Callable<T> {

        private final Callable<T> target;

        private final RequestAttributes requestAttributes;

 

        public WrappedCallable(Callable<T> target, RequestAttributes requestAttributes) {

            this .target = target;

            this .requestAttributes = requestAttributes;

        }

 

        @Override

        public T call() throws Exception {

            try {

                RequestContextHolder.setRequestAttributes(requestAttributes);

                return target.call();

            } finally {

                RequestContextHolder.resetRequestAttributes();

            }

        }

    }  

}

加上这个就可以了,亲测三种方法均可行。 

Feign中增加请求头

最近遇到项目在调用

实现RequestInterceptor 接口,然后可以根据feignClient中的值加到请求头中,使用时候在feignClient中配置,这样就可以把参数传入feign中

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

import com.alibaba.fastjson.JSONObject;

import com.google测试数据mon.collect.Lists;

import feign.RequestInterceptor;

import feign.RequestTemplate;

import org.apache测试数据mons.collections4.CollectionUtils; 

import java.util.ArrayList;

import java.util.Collection;

import java.util.List;

import java.util.Map;

  

public class FeignConfiguration implements RequestInterceptor {  

    @Override

    public void apply(RequestTemplate template) {

 

        List<String> list = new ArrayList<>();

        if ( "get" .equalsIgnoreCase(template.method())){

            Map<String, Collection<String>> queries = template.queries();

            list = (List<String>) queries.get( "key" );

 

        } else if ( "post" .equalsIgnoreCase(template.method())){

            byte [] body = template.body();

            Map<String, Object> map = JSONObject.parseObject(body, Map. class );

            Object key = map.get( "key" );

            if (key != null ){

                list.add(key.toString());

            }

        }

        if (CollectionUtils.isNotEmpty(list)) {

            template.header( "head" , list);

        }

    } 

}

?

1

2

3

4

5

6

7

8

9

10

11

import com.hbasesoft.vcc.sgp.integral.goods.config.FeignConfiguration;

import org.springframework.cloud.openfeign.FeignClient;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.RequestParam; 

 

@FeignClient (name = "test" , path = "/test" , configuration = FeignConfiguration. class )

public interface ErpGoodsCouponsExternalClient {

 

    @GetMapping ( "/url" )

    Object getData( @RequestParam ( "key" ) String key);    

}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

原文链接:https://blog.csdn.net/lidai352710967/article/details/88680173

查看更多关于使用Feign调用时添加验证信息token到请求头方式的详细内容...

  阅读:38次