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