Feign调用中的两种Header传参方式

Feign调用中的两种Header传参方式,第1张

在请求拦截器中统一配置

适用于当一个调用链涉及到多个微服务,一些参数需要在整个调用链中传递。比如为了安全每个服务都需要对请求头中token的校验。

然后在feignClient中配置自定义的配置类,覆盖默认的配置

通过@RequestHeader注解

有时候我们需要传一些自定义的header参数,而不需要传全部header参数,只需要在调用的接口上添加@RequestHeader注解,Feign调用时,会自动分装成header参数

前面我们已经实现了服务的注册与发现(请戳:SpringCloud系列——Eureka 服务注册与发现),并且在注册中心注册了一个服务myspringboot,本文记录多个服务之间使用Feign调用。

GitHub地址:https://github.com/OpenFeign/feign

官方文档:https://cloud.spring.io/spring-cloud-static/spring-cloud-openfeign/2.1.0.RC2/single/spring-cloud-openfeign.html

提供者除了要在注册中心注册之外,不需要引入其他东西,注意以下几点即可:

1、经测试,默认情况下,feign只能通过@RequestBody传对象参数

2、接参只能出现一个复杂对象,例:public Result<list >list(@RequestBody UserVo entityVo) { ... }</list

3、提供者如果又要向其他消费者提供服务,又要向浏览器提供服务,建议保持原先的Controller,新建一个专门给消费者的Controller

测试Controller接口

消费者maven引入jar

配置文件

对日期的解析,消费者要跟提供者一致,不然会报json解析错误

服务调用

1、springdatejpa 应用名称,是服务提供者在eureka注册的名字,Feign会从注册中心获取实例

2、如果不想启动eureka服务,直连本地开发:@FeignClient(name = "springdatejpa", path = "/user/",url = "http://localhost:10086"),或者无eureka,调用第三方服务,关闭eureka客户端(eureka.client.enabled=false),url直接指定第三方服务地址,path指定路径,接口的方法指定接口

3、如果使用@RequestMapping,最好指定调用方式

4、消费者的返回值必须与提供者的返回值一致,参数对象也要一致

5、2019-05-21补充:如需进行容错处理(服务提供者发生异常),则需要配置fallback,如果需要获取到报错信息,则要配置fallbackFactory ,例:

Feign接口

更多@FeignClient注解参数配置,请参阅官方文档

Controller层

启动类

启动类加入注解:@EnableFeignClients

成功注册两个服务

成功调用

1、启动时报了个SQL错误

解决:配置文件连接数据时指定serverTimezone=GMT%2B8

2、当我将之前搭好的一个springboot-springdata-jpa整合项目在eureka注册时出现了一个报错

然后在网上查了下说是因为springboot版本问题(请戳:http://www.cnblogs.com/hbbbs/articles/8444013.html),之前这个项目用的是2.0.1.RELEASE,现在要在eureka注册,pom引入了就出现了上面的报错

解决:升级了springboot版本,2.1.0,项目正常启动

2019-10-17补充 :Feign设置header请求头

方法1,mapping的headers属性,单一设置

方法2,自定义FeignInterceptor,全局设置

这样就可以设置cookie,传递token等自定义值

常见场景1

通常我们一个服务web层、svc层、dao层,但有时候也会将拆分成两个服务:

web服务提供静态资源、页面以及controller控制器控制跳转,数据通过java调用svc服务获取;

svc服务,进行 *** 作数据库以及业务逻辑处理,同时提供接口给web服务调用;

特殊情况下我们想svc服务的接口也做登录校验,所有接口(除了登录请求接口)都有做登录校验判断,未登录的无权访问,这时候就需要做sessionId传递,将web服务的sessionId通过Feign调用时传递到svc服务

web服务

注:登录成功后用sessionId作为key,登录用户的id作为value,保存到redis缓存中

登录拦截器

自定义FeignInterceptor

svc服务

会话期的sessionId,关闭浏览器后就失效了,所以就会退出浏览器后就需要重新登陆,有些情况我们并不想这样,我们想实现七天免登陆,这时候就需要自定义token,并且存放在cookie

登陆拦截器

登陆成功,设置cookie

推出登陆,销毁cookie

代码已经开源、托管到我的GitHub、码云:

GitHub:https://github.com/huanzi-qch/springCloud

码云:https://gitee.com/huanzi-qch/springCloud

作者:huanzi-qch

出处:https://www.cnblogs.com/huanzi-qch

不知道你说的是在哪里获取请求头,如果在webFilter中可以通过ServerWebExchange获取,在controller中可以直接用@RequestHeader

传递动态请求头的话可以使用feign的手动创建方式

下面的代码根据官方的改了改

@RestController

@Import(FeignClientsConfiguration.class)

public class TestController {

//这个是feign接口,里面有个test方法

private UserApi userApi

//构造器所需的参数由FeignClientsConfiguration添加到容器

public TestController(Decoder decoder, Encoder encoder, Client client, Contract contract) {

userApi = Feign.builder()

//添加header,其实还是RequestInterceptor子类,不过这个会生效

.requestInterceptor(template ->template.header("a", "999"))

.contract(contract)

.decoder(decoder)

.encoder(encoder)

.client(client)

.target(UserApi.class, "http://tbbs-user")

}

@GetMapping("/test")

public void test() {

userApi.test()

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11536398.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存