JAVA 项目中如何实现接口调用?
    1)Httpclient
    HttpClient 是 Apache Jakarta Common 下的子项目,用来提供高效的、最新的、功能丰富的支持 Http 协议的客户端编程工具包,并且它支持 HTTP 协议最新版本和建议。HttpClient 相比传统 JDK 自带的 URLConnection,提升了易用性和灵活性,使客户端发送 HTTP 请求变得容易,提高了开发的效率。
    2)Okhttp
    一个处理网络请求的开源项目,是安卓端最火的轻量级框架,由 Square 公司贡献,用于替代 HttpUrlConnection 和 Apache HttpClient。OkHttp 拥有简洁的 API、高效的性能,并支持多种协议(HTTP/2 和 SPDY)。
    3)HttpURLConnection
    HttpURLConnection 是 Java 的标准类,它继承自 URLConnection,可用于向指定网站发送 GET 请求、POST 请求。HttpURLConnection 使用比较复杂,不像 HttpClient 那样容易使用。
    4)RestTemplate WebClient
    RestTemplate 是 Spring 提供的用于访问 Rest 服务的客户端,RestTemplate 提供了多种便捷访问远程 HTTP 服务的方法,能够大大提高客户端的编写效率。
    上面介绍的是最常见的几种调用接口的方法,我们下面要介绍的方法比上面的更简单、方便,它就是 Feign。
    1. 什么是Feign
    Feign是Netflix开发的声明式、模板化的HTTP客户端,其灵感来自Retrofit、JAXRS-2.0以及WebSocket。Feign可帮助我们更加便捷、优雅地调用HTTP API。
    Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。
    Spring Cloud openfeign对Feign进行了增强,使其支持Spring MVC注解,另外还整合了Ribbon和Nacos,从而使得Feign的使用更加方便
    1.1 优势
    Feign可以做到使用 HTTP 请求远程服务时就像调用本地方法一样的体验,开发者完全感知不到这是远程方法,更感知不到这是个 HTTP 请求。它像 Dubbo 一样,consumer 直接调用接口方法调用 provider,而不需要通过常规的 Http Client 构造请求再解析返回数据。它解决了让开发者调用远程接口就跟调用本地方法一样,无需关注与远程的交互细节,更无需关注分布式环境开发。
    2. Spring Cloud Alibaba快速整合OpenFeign
    1)引入依赖

    1. <!-- openfeign 远程调用 -->
    2. <dependency>
    3. <groupId>org.springframework.cloud</groupId>
    4. <artifactId>spring-cloud-starter-openfeign</artifactId>
    5. </dependency>

    2)编写调用接口+@FeignClient注解

    1. @FeignClient(value = "mall-order",path = "/order")
    2. public interface OrderFeignService {
    3. @RequestMapping("/findOrderByUserId/{userId}")
    4. public R findOrderByUserId(@PathVariable("userId") Integer userId);
    5. }

    3)调用端在启动类上添加@EnableFeignClients注解

    1. @SpringBootApplication
    2. @EnableFeignClients
    3. public class MallUserFeignDemoApplication {
    4. public static void main(String[] args) {
    5. SpringApplication.run(MallUserFeignDemoApplication.class, args);
    6. }
    7. }

    4)发起调用,像调用本地方式一样调用远程服务

    1. @RestController
    2. @RequestMapping("/user")
    3. public class UserController {
    4. @Autowired
    5. OrderFeignService orderFeignService;
    6. @RequestMapping(value = "/findOrderByUserId/{id}")
    7. public R findOrderByUserId(@PathVariable("id") Integer id) {
    8. //feign调用
    9. R result = orderFeignService.findOrderByUserId(id);
    10. return result;
    11. }
    12. }

    3. Spring Cloud Feign的自定义配置及使用
    Feign 提供了很多的扩展机制,让用户可以更加灵活的使用。
    3.1 日志配置
    有时候我们遇到 Bug,比如接口调用失败、参数没收到等问题,或者想看看调用性能,就需要配置 Feign 的日志了,以此让 Feign 把请求信息输出来。
    1)定义一个配置类,指定日志级别

    1. // 注意: 此处配置@Configuration注解就会全局生效,如果想指定对应微服务生效,就不能配置
    2. public class FeignConfig {
    3. /**
    4. * 日志级别
    5. *
    6. * @return
    7. */
    8. @Bean
    9. public Logger.Level feignLoggerLevel() {
    10. return Logger.Level.FULL;
    11. }
    12. }

    通过源码可以看到日志等级有 4 种,分别是:

    • NONE【性能最佳,适用于生产】:不记录任何日志(默认值)。
    • BASIC【适用于生产环境追踪问题】:仅记录请求方法、URL、响应状态代码以及执行时间。
    • HEADERS:记录BASIC级别的基础上,记录请求和响应的header。
    • FULL【比较适用于开发及测试环境定位问题】:记录请求和响应的header、body和元数据。

    2) 局部配置,让调用的微服务生效,在@FeignClient 注解中指定使用的配置类
    image.png
    3) 在yml配置文件中执行 Client 的日志级别才能正常输出日志,格式是”logging.level.feign接口包路径=debug”

    1. logging:
    2. level:
    3. com.tuling.mall.feigndemo.feign: debug

    测试:BASIC级别日志
    image.png
    补充:局部配置可以在yml中配置
    对应属性配置类: org.springframework.cloud.openfeign.FeignClientProperties.FeignClientConfiguration

    1. feign:
    2. client:
    3. config:
    4. mall-order: #对应微服务
    5. loggerLevel: FULL