Spring feign时设置header信息
最近使用 SpringBoot 项目,把一些 http 请求转为 使用 feign方式。但是遇到一个问题:个别请求是要设置header的。
于是,查看官方文档和博客,大致推荐两种方式。也可能是我没看明白官方文档。
接口如下:
1
2
3
4
5
6
7
|
@FeignClient (url = "XX_url" , value = "XXService" ) public interface XXService { @RequestMapping (value = "/xx" , method = RequestMethod.POST) @Headers ({ "Content-Type: application/json" , "Accept: application/json" }) String sendDing(String params); } |
1. 使用Headers注解。直接在请求上或者在类上添加
这种方式经过尝试,没有作用。暂时不清楚原因。
2. 通过实现RequestInterceptor接口,完成对所有的Feign请求,设置Header
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
@Component public class FeginClientConfig { @Bean public RequestInterceptor headerInterceptor() { return new RequestInterceptor() { @Override public void apply(RequestTemplate requestTemplate) { // 小示例,没什么卵用 requestTemplate.header( "Content-Type" , "application/json" ); } }; } @Bean public Logger.Level level() { return Logger.Level.FULL; } } |
这种方式,是针对所有feign请求进行拦截,设置Header,不适于我的需求。
后来发现其实我的思路走偏了。咨询了一个同事,既然使用的是RequestMapping注解。那么直接使用RequestMapping注解的header属性就可以了。如下:
1
|
@RequestMapping (value = "/xx" , method = RequestMethod.POST, headers = { "content-type=application/x-www-form-urlencoded" }) |
有一点需要注意:content-type=application/x-www-form-urlencoded。此时,方法里接收的参数,就不能直接是一个对象(Map等)。不然还是会默认
content-type为 application/json.
1
2
|
@RequestMapping (value = "/xx" , method = RequestMethod.POST, headers = { "content-type=application/x-www-form-urlencoded" }) String login( @RequestParam ( "username" ) String username, @RequestParam ( "password" ) String password; |
Feign动态设置Header
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
/** * @author Liangzhifeng * date: 2018/9/13 */ public interface UserInfoFeignClient { /** * 根据token获取用户信息 * @param token * @return */ @RequestMapping (value = "/user/info/1.0" , method = RequestMethod.POST) Object getUserInfoByToken( @RequestParam ( "token" ) String token); } /** * @author Liangzhifeng * date: 2018/9/15 */ @Component public class AuthorityConfig { /** * 授权信息Header的key */ public static final String OAUTH_KEY = "token" ; /** * 授权信息Header的值的前缀 */ public static final String OAUTH_VALUE_PREFIX = "Bearer " ; // GlobalConstant.AUTHORITY_SERVICE_LINK : 服务的名称 @Autowired private Client client; public UserInfoFeignClient userInfoFeignClient(String token) { UserInfoFeignClient authorityServiceLoginInvoker = Feign.builder().client(client) .encoder( new GsonEncoder()) .decoder( new GsonDecoder()) .contract( new SpringMvcContract()) .requestInterceptor(template -> template.header(OAUTH_KEY, OAUTH_VALUE_PREFIX + token)) .target(UserInfoFeignClient. class , GlobalConstant.AUTHORITY_SERVICE_LINK); return authorityServiceLoginInvoker; } } |
接口调用:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
@Autowired private AuthorityConfig authorityConfig; /** * 根据token获取用户信息 * * @param token 用户登录的授权token * @return 用户信息JSON */ public Object getUserInfo(String token) { try { Object userInfo = authorityConfig.userInfoFeignClient(token).getUserInfoByToken(token); return userInfo; } catch (Exception e) { log.info( "获取用户信息异常" , e); return null ; } } |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/hui-run/p/8969702.html