当前位置: 首页 > news >正文

Spring HTTP Interface 入门案例介绍

Spring HTTP Interface 是 Spring 6 和 Spring Boot 3.0 引入的声明式 HTTP 客户端特性,允许通过接口和注解定义 HTTP 请求,无需手动编写 HTTP 调用代码。以下是核心要点:


一、核心特性

  1. 声明式接口定义
    通过 Java 接口 + 注解(如@GetExchange)定义 HTTP 请求,类似 Feign

    例如:

    public interface UserApiService {@GetExchange("/users")List<User> getUsers();
    }
    
  2. 运行时代理实现
    Spring 自动生成接口的代理类,底层基于 WebClient(响应式)或未来的 RestTemplate 实现。

  3. 简化依赖管理
    仅需添加spring-boot-starter-webflux依赖即可启用,无需引入第三方库(如 OpenFeign)


二、使用步骤

1. 添加依赖

首先,你需要在你的项目中添加 Spring Boot 和 Spring webflux 的依赖。可以在pom.xml文件中添加以下依赖:

<dependencies><dependency><groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-webflux</artifactId></dependency>
</dependencies>
2. 创建 HTTP 接口

接下来,你可以创建一个接口来定义你的 HTTP 请求。Spring HTTP Interface 使用注解来标记请求的方法和路径。以下是一个简单的示例:

import org.springframework.web.service.annotation.GetExchange;  
import org.springframework.web.service.annotation.HttpExchange;  
import reactor.core.publisher.Mono;  // 使用 @HttpExchange 注解来指定基础 URL 和请求头信息 
@HttpExchange(url = "https://jsonplaceholder.typicode.com",  accept = "application/json") 
public interface JsonPlaceholderService { // 使用 @GetExchange 注解来指定具体的请求路径 // 该方法用于获取一个用户的信息,返回一个 Mono 对象,Mono 是 Reactor 库中的一种响应式类型,表示最多包含一个元素的异步序列 @GetExchange("/users/1") Mono<String> getUser(); 
} 

在上述代码中:

@HttpExchange注解用于指定基础 URL 和请求头信息,这里的基础 URL 是https://jsonplaceholder.typicode.com

请求头中accept字段为application/json,表示期望接收 JSON 格式的数据。

@GetExchange注解用于指定具体的请求路径,这里的路径是/users/1,表示获取 ID 为 1 的用户信息。

Mono<String>表示该方法返回一个异步的字符串结果,使用Mono是为了支持响应式编程。

3. 配置 HTTP 客户端

创建一个配置类: JsonPlaceholderService,用于配置 HTTP 客户端和初始化

import org.springframework.context.annotation.Bean;  
import org.springframework.context.annotation.Configuration;  
import org.springframework.web.reactive.function.client.WebClient;  
import org.springframework.web.service.invoker.HttpServiceProxyFactory;  @Configuration 
public class HttpServiceConfig { // 定义一个 WebClient Bean,用于发送 HTTP 请求 @Bean public WebClient webClient() { return WebClient.builder().build();  } // 定义一个 JsonPlaceholderService Bean,使用 HttpServiceProxyFactory 来创建接口的代理实例 @Bean public JsonPlaceholderService jsonPlaceholderService(WebClient webClient) { // 创建 HttpServiceProxyFactory 实例,并使用 WebClientAdapter 将 WebClient 适配到工厂中 HttpServiceProxyFactory factory = HttpServiceProxyFactory.builder()  .clientAdapter(org.springframework.web.reactive.function.client.support.WebClientAdapter.forClient(webClient))  .build(); // 使用工厂创建 JsonPlaceholderService 接口的代理实例 return factory.createClient(JsonPlaceholderService.class);  } 
} 
4. 测试调用

创建一个测试类,用于测试

import org.junit.jupiter.api.Test;  
import org.springframework.beans.factory.annotation.Autowired;  
import org.springframework.boot.test.context.SpringBootTest;  
import reactor.test.StepVerifier;  @SpringBootTest 
public class JsonPlaceholderServiceTest { // 注入 JsonPlaceholderService 实例 @Autowired private JsonPlaceholderService jsonPlaceholderService; @Test public void testGetUser() { // 调用 JsonPlaceholderService 接口的 getUser 方法,获取一个 Mono 对象 var result = jsonPlaceholderService.getUser();  // 使用 StepVerifier 来验证 Mono 对象的结果 StepVerifier.create(result)  .expectNextMatches(response -> response.contains("\"id\":  1")) .verifyComplete(); } 
} 

三、优势与适用场景

  1. 简化代码
    将 HTTP 请求抽象为 Java 方法,减少模板代码,提升开发效率15。
  2. 集成 Spring 生态
    支持参数绑定、错误处理、拦截器等,与 Spring 特性无缝兼容36。
  3. 响应式支持
    默认基于 WebClient,适合响应式和非阻塞场景16。

四、注意事项

  1. 版本要求
    Spring Boot ≥ 3.0 且 JDK ≥ 1737。
  2. 依赖限制
    目前仅支持 WebClient 实现,RestTemplate 支持待后续版本36。
  3. 与 Feign 对比
    功能类似,但 HTTP Interface 是 Spring 原生方案,适合新项目;已有 Feign 项目可逐步迁移57。

五、扩展应用

  • 复杂请求处理:支持路径变量、请求头、表单参数等注解配置6。
  • 错误处理:自定义异常映射和降级逻辑6。
  • 测试:结合 MockWebServer 或 Spring Boot Test 进行单元测试2。

相关文章:

  • sentinel安装部署及测试--实践
  • 在Vmware15(虚拟机免费) 中安装纯净win10详细过程
  • RK3588 实现音视频对讲
  • Oracle 12.1.0.2补丁安装全流程
  • 如何使用3DMAX插件PFSpliner将3D对象转化为艺术样条线?
  • AOP的基本应用案例---统计每个函数的执行时间
  • IntelliJ IDEA 项目导入后 Java 文件图标显示为红色小写 j 的解决方法
  • LVS+keepalived搭建高可用架构
  • 资源直方图与资源平衡技术在资源约束下的作用是什么?
  • Paramiko 使用教程
  • [特殊字符] UnionFS(联合文件系统)原理解析:容器背后的存储技术
  • css button 点击效果
  • Github 2025-04-17 Go开源项目日报 Top9
  • Go:低级编程
  • QT 初体验
  • 无源蓝牙技术与传统RFID(射频识别)对比
  • 使用DDR4控制器实现多通道数据读写(八)
  • 在极狐GitLab 身份验证中如何使用 OIDC?
  • 大数据分析02 基础语法差异
  • 【FFmpeg从入门到精通】第二章-FFmpeg工具使用基础
  • 九江宜春领导干部任前公示,3人拟提名为县(市、区)长候选人
  • 政企共同发力:多地密集部署外贸企业抢抓90天政策窗口期
  • 艺术稀缺性和价值坚守如何构筑品牌差异化壁垒?从“心邸”看CINDY CHAO的破局之道
  • 共建医学人工智能高地,上海卫健委与徐汇区将在这些方面合作
  • 基金经理调仓引发大金融板块拉升?公募新规落地究竟利好哪些板块
  • 诠释微末处的丰盈:“上海制造佳品汇”首届海外专场即将亮相日本大阪