SpringBoot3.4.3基于Openfeign实现声明式http接口调用
SpringBoot3.4.3基于Openfeign实现声明式http接口调用

本专栏前一篇文章SpringBoot3.4.3基于SpringDoc2和Swagger3实现项目接口文档管理。今天分享SpringBoot3.4.3基于openfeign实现http声明式接口调用功能,通过声明简单的注解即可完成跨服务http接口调用。
完整代码在文章最后,如果觉得本篇文章对你有用,记得点赞、关注、收藏哦。你的支持是我持续更新的动力!
文章最后可以加入免费的Java&AI技术和支付系统沟通社群,一起探讨Java/你的产品如何与AI结合,请按照要求加入。在群中可以聊开发、系统设计、架构、行业趋势、AI等等话题
SpringBoot3专栏软件环境
- JDK17.0.12
- SpringBoot3.4.3
- IDEA2024.3.3
- Openfeign13.5
我们先看本篇文章对应的项目结构,请看下图

1 什么是OpenFeign
- OpenFeign 是一个声明式的 Web 服务客户端,它使得编写 HTTP 客户端变得更加简单。
- 声明式服务调用:通过注解定义接口,简化了HTTP客户端的开发。
- 集成Spring Cloud:与Spring Cloud生态中的其他组件(如Eureka、Ribbon、Hystrix等)无缝集成,提供负载均衡和服务熔断等功能。
- 自动序列化和反序列化:支持请求参数和响应结果的自动转换,通常使用Jackson或Gson进行JSON处理。
- 可插拔的日志级别配置:可以根据需要配置不同级别的日志输出。
2 项目搭建
今天的代码分为两部分第一部分为OpenFeign客户端项目,用于发起http调用。另外一个服务为服务提供方,用于接收客户端的http请求并响应数据给客户端。项目都是基于SpringBoot3
2.1 pom依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>cn.itbeien</groupId>
<artifactId>springboot3-labs-master</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<artifactId>springboot-openfeign</artifactId>
<packaging>pom</packaging>
<modules>
<module>springboot-openfeign-client</module>
<module>springboot-openfeign-service</module>
</modules>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<openfeign-version>13.5</openfeign-version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-core</artifactId>
<version>${openfeign-version}</version>
</dependency>
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-gson</artifactId>
<version>${openfeign-version}</version>
</dependency>
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-spring4</artifactId>
<version>${openfeign-version}</version>
</dependency>
</dependencies>
</project>
2.2 Openfeign配置
package cn.itbeien.openfeign.config;
import cn.itbeien.openfeign.feign.ServiceFeignClient;
import feign.Feign;
import feign.gson.GsonDecoder;
import feign.gson.GsonEncoder;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* @author itbeien
* 项目网站:https://www.itbeien.cn
* 公众号:贝恩聊架构
* 全网同名,欢迎小伙伴们关注
* Java/AI学习社群
* Copyright© 2025 itbeien
*/
@Configuration
public class FeignConfig {
@Value("${api.serviceUrl}")
private String serviceUrl;
@Bean
public ServiceFeignClient serviceFeignClient() {
return Feign.builder()
.encoder(new GsonEncoder())
.decoder(new GsonDecoder())
.target(ServiceFeignClient.class, serviceUrl); // 服务提供者地址
}
}
2.3 声明式http接口
package cn.itbeien.openfeign.feign;
import cn.itbeien.openfeign.feign.vo.UserRequest;
import cn.itbeien.openfeign.feign.vo.UserResponse;
import feign.Headers;
import feign.Param;
import feign.QueryMap;
import feign.RequestLine;
import java.util.List;
import java.util.Map;
/**
* @author itbeien
* 项目网站:https://www.itbeien.cn
* 公众号:贝恩聊架构
* 全网同名,欢迎小伙伴们关注
* Java/AI学习社群
* Copyright© 2025 itbeien
*/
public interface ServiceFeignClient {
// 获得用户详情
@RequestLine("GET /api/get?id={id}")
UserResponse get(@Param("id") Integer id);
@RequestLine("GET /api/list?name={name}&gender={gender}")
List<UserResponse> list(@Param("name") String name,
@Param("gender") Integer gender);
@RequestLine("GET /api/list")
List<UserResponse> list(@QueryMap Map<String, Object> queryMap);
@RequestLine("POST /api/add")
@Headers("Content-Type: application/json")
Integer add(UserRequest request);
}
3 单元测试
使用Openfeign声明式接口调用该服务端接口
package cn.itbeien.openfeign.test;
import cn.itbeien.openfeign.feign.ServiceFeignClient;
import cn.itbeien.openfeign.feign.vo.UserResponse;
import cn.itbeien.openfeign.feign.vo.UserRequest;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* @author itbeien
* 项目网站:https://www.itbeien.cn
* 公众号:贝恩聊架构
* 全网同名,欢迎小伙伴们关注
* Java/AI学习社群
* Copyright© 2025 itbeien
*/
@SpringBootTest
@Slf4j
public class ServiceApiTest {
@Autowired
private ServiceFeignClient serviceFeignClient;
@Test
public void get() {
UserResponse response = serviceFeignClient.get(3);
log.info("response: {}", response);
}
@Test
public void list() {
List<UserResponse> responseList = serviceFeignClient.list("itbeien", 1);
log.info("responseList: {}", responseList);
}
@Test
public void test() {
Map<String, Object> queryMap = new HashMap<>();
queryMap.put("name", "itbeien");
List<UserResponse> responspList = serviceFeignClient.list(queryMap);
log.info("responspList: {}", responspList);
}
@Test
public void add() {
UserRequest request =new UserRequest();
request.setName("itbeien");
request.setGender(2);
Integer id = serviceFeignClient.add(request);
log.info("id: {}", id);
}
}

以上就是今天SpringBoot3.4.3基于Openfeign实现声明式http接口调用功能全部内容,文章最后有源码下载地址
欢迎大家关注我的项目实战内容itbeien.cn,一起学习一起进步,在项目和业务中理解各种技术。

欢迎沟通交流技术和支付业务,一起探讨聚合支付/预付卡系统业务、技术、系统架构、微服务、容器化。并结合聚合支付系统深入技术框架/微服务原理及分布式事务原理。加入我的知识星球吧

AI专栏
01IDEA&VsCode集成DeepSeek-V3 API提高编程效率
02IntelliJ IDEA集成主流 AI 编程助手及特性介绍
03Spring AI快速入门-基于DeepSeek&智谱实现聊天应用
04Spring AI中流式对话API如何使用-基于DeepSeek
06SpringAI实现角色扮演(自定义人设)和Prompts模板语法-基于DeepSeek
07LangChain4j实战-Java AI应用开源框架之LangChain4j和Spring AI
SpringBoot3专栏
01SpringBoot3专栏-SpringBoot3.4.0整合Mybatis-plus和Mybatis
02SpringBoot3.4.0结合Mybatis-plus实现动态数据源
03mapstruct对象映射在Springboot3中这样用就对了
04RocketMQ5.3.1集成SpringBoot3.4.0就这样简单
05SpringBoot3.4.0整合Redisson实现分布式锁
06MySQL增量数据同步利器Canal1.1.7环境搭建流程
07SpringBoot3.4.0集成Canal1.1.7实现MySQL实时同步数据到Redis
08基于Docker-SpringBoot3.4.0集成Apache Pulsar4.0.1实现消息发布和订阅
09SpringBoot3.4.0整合消息中间件Kafka和RabbitMQ
10SpringBoot3.4.0整合ActiveMQ6.1.4
11SpringBoot3整合Spring Security6.4.2 安全认证框架实现简单身份认证
12SpringBoot3.4.1和Spring Security6.4.2实现基于内存和MySQL的用户认证
13SpringBoot3.4.1和Spring Security6.4.2结合OAuth2实现GitHub授权登录
14SpringBoot3.4.1和Spring Security6.4.2结合JWT实现用户登录
16SpringBoot3.4.1基于MySQL8和Quartz实现定时任务管理
17SpringBoot3.4.2基于MyBatis和MySQL8多数据源使用示例
18SpringBoot3.4.3实现(文本/附件/HTML/图片)类型邮件发送案例
19SpringBoot3.4.3实现文件上传和全局异常处理
20SpringBoot3.4.3集成Knife4j实现接口文档管理和调试
21SpringBoot3.4.3基于Caffeine实现本地缓存
22SpringBoot3.4.3基于Spring WebFlux实现SSE功能
23SpringBoot3.4.3基于SpringDoc2和Swagger3实现项目接口文档管理
跟着我学微服务系列
01跟着我学微服务,什么是微服务?微服务有哪些主流解决方案?
05SpringCloudAlibaba之图文搞懂微服务核心组件在企业级支付系统中的应用
06JDK17+SpringBoot3.4.0+Netty4.1.115搭建企业级支付系统POS网关
07JDK17+SpringCloud2023.0.3搭建企业级支付系统-预付卡支付交易微服务
08JDK17+Dubbo3.3.2搭建企业级支付系统-预付卡支付交易微服务
09JDK17+SpringBoot3.3.6+Netty4.1.115实现企业级支付系统POS网关签到功能
贝恩聊架构-项目实战地址
欢迎大家一起讨论学习,加我备注"Java/AI"拉你进入Java&AI技术讨论群,备注"聚合支付"拉你进入支付系统讨论群,在技术学习、成长、工作的路上不迷路!加我后不要急,每天下午6点左右通过!营销号免入

4 源码地址
贝恩聊架构-SpringBoot3专栏系列文章、资料和源代码会同步到以下地址,代码和资料每周都会同步更新
该仓库地址主要用于存放贝恩聊架构-SpringBoot3专栏、贝恩聊架构-AI专栏、基于企业级支付系统学习微服务整体技术栈所有资料和源码
