如何自定义一个 Spring Boot Starter?

目录

[一、创建 Starter 项目结构](#一、创建 Starter 项目结构)

二、创建自动配置类

三、创建配置属性类

四、创建业务服务类

五、注册自动配置类

[六、使用 Maven 打包项目](#六、使用 Maven 打包项目)

[七、在其他 Spring Boot 项目中使用 Starter](#七、在其他 Spring Boot 项目中使用 Starter)

[1. 引入 Starter 依赖](#1. 引入 Starter 依赖)

[2. 直接注入使用](#2. 直接注入使用)


一、创建 Starter 项目结构

Spring Boot 官方建议第三方 Starter 的命名格式为:xxx-spring-boot-starter

因此我们创建一个名为 my-spring-boot-starter的 Maven 项目,并包含两个模块:

perl 复制代码
my-spring-boot-starter
├── my-spring-boot-autoconfigure
└── my-spring-boot-starter

模块职责说明

  • autoconfigure 模块
    • 存放自动配置逻辑
    • 包含自动配置类、配置属性类、业务类
  • starter 模块
    • 只包含依赖声明
    • 对外作为 Starter 使用

二、创建自动配置类

在 my-spring-boot-autoconfigure 模块中创建自动配置类,一般放在 autoconfigure 包下。

java 复制代码
@Configuration
@EnableConfigurationProperties(MyProperties.class)
@ConditionalOnClass(MyService.class)
@ConditionalOnMissingBean(MyService.class)
public class MyAutoConfiguration {

    @Bean
    public MyService myService(MyProperties properties) {
        return new MyService(properties.getPrefix());
    }
}

说明

  • @Configuration:声明这是一个配置类
  • @EnableConfigurationProperties:启用配置属性绑定
  • @ConditionalOnClass:类存在时才生效
  • @ConditionalOnMissingBean:用户未自定义 Bean 时才创建

三、创建配置属性类

配置属性类用于读取 application.yml 或 application.properties 中的配置。

java 复制代码
@ConfigurationProperties(prefix = "my.starter")
public class MyProperties {

    private String prefix = "Hello";

    public String getPrefix() {
        return prefix;
    }

    public void setPrefix(String prefix) {
        this.prefix = prefix;
    }
}

对应配置文件示例:

perl 复制代码
my:
  starter:
    prefix: Hi

四、创建业务服务类

创建一个简单的服务类,用于提供具体业务逻辑。

java 复制代码
public class MyService {

    private final String prefix;

    public MyService(String prefix) {
        this.prefix = prefix;
    }

    public String sayHello(String name) {
        return prefix + " " + name;
    }
}

该类不需要任何 Spring 注解,由自动配置类负责注册。

五、注册自动配置类

在 my-spring-boot-autoconfigure 模块的:

css 复制代码
src/main/resources/META-INF

目录下创建文件:spring.factories

内容如下:

XML 复制代码
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.example.autoconfig.MyAutoConfiguration

该文件用于告诉 Spring Boot:在启动时加载我们自定义的自动配置类。

六、使用 Maven 打包项目

在父工程目录执行:

bash 复制代码
mvn clean install

打包完成后:

  • autoconfigure 模块作为普通依赖
  • starter 模块作为最终对外使用的 Starter

七、在其他 Spring Boot 项目中使用 Starter

1. 引入 Starter 依赖

XML 复制代码
<dependency>
    <groupId>com.example</groupId>
    <artifactId>my-spring-boot-starter</artifactId>
    <version>1.0.0</version>
</dependency>

2. 直接注入使用

java 复制代码
@RestController
public class TestController {

    @Autowired
    private MyService myService;

    @GetMapping("/hello")
    public String hello(String name) {
        return myService.sayHello(name);
    }
}

无需任何额外配置,即可正常使用。

通过以上步骤,我们完成了一个自定义 Spring Boot Starter:

  • Starter 模块负责依赖聚合
  • AutoConfigure 模块负责自动装配
  • 利用条件注解保证安全、可扩展

自定义 Spring Boot Starter 的核心,就是通过自动配置机制,把通用功能封装成"引入即用"的模块。

相关推荐
王五周八几秒前
Tesseract OCR的Java使用(附安装包,非常详细)
java·开发语言·ocr
旧书包的青春几秒前
2026年6月11日
java
实在智能RPA13 分钟前
航空Agent落地效果评估指标:2026年企业级智能自动化价值度量体系拆解
java·网络·人工智能·ai·自动化
程序员二叉19 分钟前
【JUC】AQS底层深度拆解|独占/共享模式|队列原理全详解
java·开发语言·面试·juc
地铁潜行者24 分钟前
消息堆积后,为什么一扩容消费者,MySQL 先被打崩了?
java·后端
地铁潜行者28 分钟前
订单状态更新成功了,分账消息却没发出去:聊聊本地消息表的一致性坑
java·后端
亦暖筑序28 分钟前
Java 8老系统SQL Agent实战:AI生成候选SQL,安全引擎拦截后再执行
java·人工智能·sql
CodeStats30 分钟前
《源纹天书》卷一:归元初醒(第1-5章)
java
大囚长34 分钟前
大模型服务端如何命中缓存
java·人工智能·缓存·dubbo
别叫我老干部34 分钟前
一键给整个库造测试数据:外键、约束一个都不能少
后端·mysql