Feign设置header的方式和日志打印

header设置

       在微服务间使用Feign进行远程调用时需要在 header 中添加信息,那么 springcloud open feign有5种方式可以设置请求头信息:

  • 在@RequestMapping、@GetMapping、@PostMapping等接口注解里添加headers属性
  • 在方法参数前面添加@RequestHeader注解
  • 在方法或者类上添加@Headers的注解
  • 在方法参数前面添加@HeaderMap注解
  • 实现RequestInterceptor接口

@RequestMapping、@GetMapping、@PostMapping注解里添加headers属性

@PostMapping(value = "/get", headers = {"Content-Type=application/json;charset=UTF-8")
String get();

@RequestMapping(value = "/post", method = RequestMethod.POST)
String post();

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

//设置单个header
@GetMapping(value = "/single")
public Stringsingle(@RequestHeader("Authorization") String token);

//设置多个header
@PostMapping(value = "/multi")
public String multi(@RequestHeader MultiValueMap<String, String> headers);

在方法或者类上添加@Headers的注解

//先配置feign自带契约
@Configuration
public class FeignConfiguration {
    @Bean
    public Contract feignContract() {
        return new feign.Contract.Default();
    }
}


//使用@Headers 注解
@FeignClient(url = "${user.api.url}", name = "user", configuration = FeignConfiguration .class)
public interface UserFeignClient {
    @RequestLine("GET /get/{id}")
    @Headers({"Content-Type: application/json;charset=UTF-8", "Authorization: {token}"})
    public User findById(@Param("id") String id, @Param("token") String token);
}

注意:

FeignClient使用@RequestLine注解, 而未配置feign自带契约Contract时, @Headers不会起作用, 而且启动项目会报错。

Method xxx not annotated with HTTP method type (ex. GET, POST)

这是因为feign 默认使用的是spring mvc 注解(就是RequestMapping 之类的) ,所以需要通过新增一个配置类来修改其契约。

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

//先配置feign自带契约
@Configuration
public class FeignConfiguration {
    @Bean
    public Contract feignContract() {
        return new feign.Contract.Default();
    }
}

@FeignClient(url = "${user.api.url}", name = "user", configuration = FeignConfiguration .class)
public interface UserFeignClient {
    @RequestLine("GET /get/{id}")
    public User findById(@Param("id") String id, @HeaderMap HttpHeaders headers);
}

实现RequestInterceptor接口

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

@Configuration
public class FeignRequestInterceptor implements RequestInterceptor {
    @Override
    public void apply(RequestTemplate template) {
        template.header(HttpHeaders.AUTHORIZATION, "XXXXXXX");
    }
}

如果FeignRequestInterceptor注入到spring容器的话就会全局生效, 就是说即使在没有指定configuration属性的FeignClient该配置也会生效。所以如果只想给指定FeignClient的feign接口使用该配置, 请勿将该类配置注入spring中

日志打印配置

1.配置日志级别

@Configuration
public class FeignClientConfig {
    @Bean
    Logger.Level feignLogLevel() {
        return Logger.Level.FULL;
    }
}

2. 配置logback.xml输出

<logger name="com.business.gateway.iao" level="DEBUG" additivity="false">
            <Appender-ref ref="ROLLINGFILE" />
            <Appender-ref ref="WARN" />
            <appender-ref ref="STDOUT"/>
        </logger>

3.指定输出的feigin类所在文件夹

yml配置:

logging:
  level:
    com.eshore.be.platform.external.core.service.ginfeign: DEBUG

properties配置:

logging.level. com.eshore.be.platform.external.core.service.ginfeign=DEBUG 

猜你喜欢

转载自blog.csdn.net/qq_34484062/article/details/128011166
今日推荐