传统的代码方式 使用报文构造请求参数,或者httpClient或者是okHttpClient进行访问,设置参数过多的情况一直存在
Fegin的出现很好的解决了这个问题,只需要添加一个类,继承基类,然后添加一些注解,最后直接进行访问,并且也支持springmvc的注解
由于fegin使用的契约是springmvccontract,所以我们可以使用springmvc的注解,首先添加@FeginClient这个注解,定义其name,在为其配置configuration,除了这个功能之外,我们也可以自定义fegin的编码器,解码器,日志打印,也可以添加拦截器,比如一些接口需要进行基于HttpBasic的认证后才能调用
对于fegin可以进行局部配置,也可以进行全局配置,
对于指定名称的FeginClient
我们可以按照一定的层级进行配置
fegin:
client:
config:
feginName:
connectTimeout: 5000
readTimeout: 5000
loggerLevel: full
errorDecoder: 全路径的类
retryer: 配置拦截器
decode: 400
对于全局的配置就更加简单
fegin:
client:
config:
default:
loggerLevel: basic
fegin 对继承的支持
fegin 对压缩的支持
fegin的日志,首先是fegin的日志级别我们设置为full,针对具体的logging的日志级别我们设置为debug,因为其只对这个有反应
有俩种方式可以参考
第一种就是代码的形式,大概思路
先创建一个LogConfigurtion,具体声明的类配置的configuration指向这个log类,最后在application.yml添加logging: 设置级别为dubug,
、第二种: 配置文件的形式进行配置
非常的方便简洁
fegin:
client:
config:
movie-user:
loggerLevel:full
logging:
level:
全路径类:debug
使用fegin构造多参数请求体
比如get请求,post请求
get请求最好的方式就是传参,多参数,传递map
单个参数,传递使用@requestParam
Post请求,针对实体,直接可以传递 map和对象
Fegin 也可以实现上传文件
其中使用到MultipartFile 这个对象,再加上编码等等信息
所以先引入依赖
fegin-form
fegin-form-spring
再构建具体的实现类
配置对应的参数
总结一下,fegin 可以实现编码,解码器,日志级别打印,上传文件,压缩,等等