开发者

OpenFeign设置header的三种方式总结

目录
  • 设置OpenFeign的FeignClient的Header信息
  • 1、在@RequestMapping注解里添加headers属性
  • 2、在方法参数前面添加@RequestHeader注解
  • 3、实现RequestInterceptor接口
  •  总结

设置OpenFeign的FeignClient的Header信息

在微服务间使用Feign进行远程调用时需要在 header 中添加信息,那么 SpringBoot和SpringCloud OpenFeign的@FeignClient如何设置 header 呢?有5种方式可以设置请求头信息:

&bullphp; 在@RequestMapping注解里添加headers属性

• 在方法参数前面添加@RequestHeader注解

• 实现RequestInterceptor接口

由于Feign是完全支持Spring MVC注解的, 所以推荐使用前两种Feign设置header的方式, 即: Spring MVC中使用注解设置header.

1、在@RequestMapping注解里添加headers属性

在application.yml中配置

my.name=wtl
@PostMapping(value = "/service/rest/v1/script/{scriptName}/run",headers = {"Authorization=Basic YWRtaW46QFdUTDE5OTIwMTE4MDI3MQ==","Content-Type=text/plain","xDexQbWAppSecret=${my.name}"})
    String runScript(@PathVariable("scriptName") String scriptName);

OpenFeign设置header的三种方式总结

2、在方法参数前面添加@RequestHeader注解

设置单个header属性

@PostMapping(value = "/service/rest/v1/script/{scriptName}/run",headers = {"Content-Type=text/plain","AppSecret=${my.name}"})
 
    String runScript(@PathVariabpythonle("scriptName") String scriptName,@RequestHeader("Authorization") String authorization);
public String runScript(String scriptName) {
        return nexusOpenFeign.runScript(scriptName,"Basic YWRtaW46QFdUTDE5OTIwMTE4MDI3MQ==");
    }

OpenFeign设置header的三种方式总结

设置多个header属性

@PostMapping(value = "/service/rest/v1/script/{scriptName}/run")
    String runScript(@PathVariable("scriptName") String scriptName,@RequestHeader MultiValueMap<String, String> headers);
public String runScript(String scriptName) {
        MultiValueMap<String, String> headers = new HttpHeaders();
        headers.put("Authorization", Collections.singletonList("Basic YWRtaW46QFdUTDE5OTIwww.devze.comwMTE4MDI3MQ=="));
        headers.add("Content-Type","text/plain");
        return nexusOpenFeign.runScript(scriptName,headers);
    }

OpenFeign设置header的三种方式总结

3、实现RequestInterceptor接口

如果FeignRequestInterceptor注入到spring容器的话就会开发者_Go开发全局生效, 就是说即使在没有指定configuration属性的FeignClient该配置也会生效。

配置@Component或@Service 或 @Configuration 就可以将该配置注入spring容器中, 即可实现全局配置, 从而该项目中的所有FeignClient的feign接口都可以使用该配置.

如果只想给指定FeignClient的feign接口使用该配置, 请勿将该类配置注入spring中。

@Configuration
public class FeignRequestInterceptor implements RequestInterceptor {
 
    @Override
    public void apply(RequestTemplate template)http://www.devze.com {
        template.header(HttpHeaders.AUTHORIZATION, "tokenVal");
    }
 
}
@FeignClient(url = "${user.api.url}", name = "user", configuration = FeignRequestInterceptor.class)
public interface UserFeignClient {
    @GetMapping(value = "/simple/{id}")
    public User findById(@RequestParam("id") String id);
}

 总结

到此这篇关于OpenFeign设置header的三种方式的文章就介绍到这了,更多相关OpenFeign设置header内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜