Spring 使用 feign时设置header信息的操作

网友投稿 827 2022-10-07


Spring 使用 feign时设置header信息的操作

Spring feign时设置header信息

最近使用 SpringBoot 项目,把一些 http 请求转为 使用 feign方式。但是遇到一个问题:个别请求是要设置header的。

于是,查看官方文档和博客,大致推荐两种方式。也可能是我没看明白官方文档。

接口如下:

@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

@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属性就可以了。如下:

@RequestMapping(value ="/xx", method = RequestMethod.POST, headers = {"content-type=application/x-www-form-urlencoded"})

有一点需要注意:contehttp://nt-type=application/x-www-form-urlencoded。此时,方法里接收的参数,就不能直接是一个对象(Map等)。不然还是会默认

content-type为 application/json.

@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调用接口:

/**

* @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;

}

}

接口调用:

@Autowired

private AuthorityConfig authorityConfig;

/**

* 根据token获取用户信息

*

* @param token 用户登录的授权token

* @return 用户信息JSON

*/

public Object getUserInXYqHtprfAfo(String token) {

try {

Object userInfo = authorityConfig.userInfoFeignClient(token).getUserInfoByToken(token);

return userInfo;

} catch (Exception e) {

log.info("获取用户信息异常", e);

return null;

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:企业网络安全之Knowns & Unknowns(网络系统网络安全)
下一篇:安全态势感知之我见(态势感知和安全管理平台)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~