SpringBoot自定义Starter指南

SpringBoot的Starter自动配置机制极大地简化了依赖管理和应用配置,使得开发者可以以最少的配置快速启动和运行Spring应用。

有时,标准的Starter可能无法满足特定需求,这时我们可以创建自定义Starter来扩展SpringBoot的功能。

什么是SpringBoot Starter

SpringBoot Starter是一个特殊的依赖描述符,它包含了一系列的库依赖,这些库依赖定义了某个功能领域(如web应用、数据库访问等)所需的所有类库。SpringBoot通过spring-boot-autoconfigure模块提供的自动配置机制来自动配置这些依赖。

Web应用开发

  • spring-boot-starter-web:用于创建Web应用和RESTful服务,包含Tomcat和Spring MVC。
  • spring-boot-starter-webflux:用于构建响应式Web应用,基于Reactor和Spring WebFlux。

数据库访问

  • spring-boot-starter-data-jpa:集成Spring Data JPA和Hibernate,用于关系数据库的操作。
  • spring-boot-starter-data-mongodb:用于与MongoDB数据库的集成。
  • spring-boot-starter-data-redis:用于与Redis键值存储的集成。

库依赖

把具备某些功能的坐标打包到一起,简化依赖导入。

比如导入了spring-boot-starter-web这个starter,那么和web相关的jar包都一起自动导入到项目中了。

自动配置

无需手动配置xml,由starter进行自动配置并管理bean,简化开发过程。

mybatis-spring-boot-starter为例。

1)当引入了mybatis-spring-boot-starter后,其引入的相关依赖如下:

2)它导入了一个mybatis-spring-boot-autoconfigure 的jar包,其中有一个自动配置类MybatisAutoConfiguration

3)打开看看,里面的关键代码

4)其中@Configuration@Bean注解,结合使用替代传统的xml配置文件,把SqlSessionTemplateSqlSessionFactory注入到Spring容器。

注解@EnableConfigurationProperties,其作用是让后面指定的配置属性MybatisProperties类生效。

把此类标记为一个配置属性类,prefix指定了前缀,其属性就是配置的可选参数。

如配置包的别名:mybatis.type-aliases-package=com.yyh.entity

5)那么这个MybatisAutoConfiguration类是怎么被加载的呢?

META-INF/spring.factories文件中,定义了MybatisAutoConfiguration

当 SpringBoot 应用程序启动时,会去加载该 jar 包下的META-INF/spring.factories文件。

详情可以参考:SpringBoot自动装配原理解析

命名规范

spring-boot-starter-xxx是SpringBoot官方定义的jar,如 spring-bbot-starter-web。
xxx-spring-boot-starter是非官网定义的,如第三方jar包 mybatis-spring-boot-starter。

自定义 Starter

一般来说,需要我们自定义 starter 的原因如下:

  • 封装功能:封装一组特定的功能,使其可以轻松地在其他项目中复用。
  • 简化配置:自动配置相关类库,减少重复的配置工作。
  • 模块化设计:保持应用的模块化,将特定功能隔离在单独的模块中。

比如,我们现在要新建一个 token-redis-spring-boot-starter

1)新建项目,配置 pom。

2)在包util下创建类TokenProperties,此类是一个配置属性类。

3)在包service下创建类TokenService,作为一个服务。

4)在包config下创建类TokenAutoConfiguration,实现自动配置,把服务注入到Spring中。

5)创建 spring.factories文件

java 复制代码
#后面的路径是TokenAutoConfiguration所在的路径
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
  com.example.demo.config.TokenAutoConfiguration

6)把项目打包发布到 maven 仓库。

7)新建一个项目,并引入token-redis-spring-boot-starter

8)在配置文件中配置

9)测试运行

输出:127.0.0.1,0000,8888888

条件注解

在文中出现了好几个类似于这样的注解@ConditionalXXX

比如:@ConditionalOnProperty@ConditionalOnClass@ConditionalOnMissingBean

@Conditional 是在 SpringFramework 4.0 版本正式推出的,它可以让 Bean的装载基于一些指定的条件,换句话说,被标注 @Conditional 注解的 Bean 要注册到 IOC 容器时,必须全部满足 @Conditional 上指定的所有条件才可以。

@ConditionalOnProperty

@ConditionalOnProperty 注解用于根据配置文件中的属性值来决定是否加载某个自动配置类。

  • 属性名称:可以指定一个或多个属性名称,只有当这些属性被设置时,自动配置类才会被加载。
  • 属性值:可以进一步指定需要匹配的属性值,只有当属性的值与指定值相匹配时,自动配置类才会被加载。
java 复制代码
@Configuration
@EnableConfigurationProperties({TokenProperties.class})
@ConditionalOnProperty(
    value = {"token.enabled"},
    havingValue = "true"
)
public class TokenAutoConfiguration {
    public TokenAutoConfiguration() {
    }

    @Bean
    public TokenService tokenService() {
        return new TokenService();
    }
}

在这个例子中,只有当配置文件中存在token.enabled属性,TokenAutoConfiguration类才会被加载。

@ConditionalOnClass

@ConditionalOnClass 注解用于检查类路径上是否存在某个类,如果存在,则加载自动配置类。

  • classes:指定一个或多个类,如果这些类在类路径上被找到,自动配置类就会被加载。
java 复制代码
@Configuration
@ConditionalOnClass(name = {"com.mysql.cj.jdbc.Driver"})
public class MySqlAutoConfiguration {
    // ...
}

在这个例子中,只有当类路径上存在com.mysql.cj.jdbc.Driver类时,MySqlAutoConfiguration类才会被加载,这通常意味着MySQL JDBC驱动已经添加到了项目的依赖中。

@ConditionalOnMissingBean

@ConditionalOnMissingBean 注解用于检查Spring容器中是否已经存在某个特定的Bean,如果不存在,则创建一个新的Bean。

  • value:指定需要检查的Bean的类型。
  • search:指定搜索Bean的范围,默认为SearchStrategy.ALL,意味着在当前上下文和父上下文中搜索。
java 复制代码
@Configuration
public class MyServiceAutoConfiguration {

    @Bean
    @ConditionalOnMissingBean(MyService.class)
    public MyService myService() {
        return new DefaultMyService();
    }
}

在这个例子中,如果Spring容器中没有MyService类型的Bean,那么myService方法将被调用以创建一个新的MyService Bean。

组合使用条件注解

这些条件注解可以单独使用,也可以组合使用,以满足更复杂的条件判断需求。

例如,可以同时使用@ConditionalOnProperty@ConditionalOnClass来确保某个自动配置类只在满足特定属性值和类路径上有特定类时才被加载。

java 复制代码
@Configuration
@ConditionalOnProperty(name = "myapp.enabled")
@ConditionalOnClass(name = "com.mysql.cj.jdbc.Driver")
public class MySqlAutoConfiguration {
    // ...
}

在这个例子中,MySqlAutoConfiguration只有在配置文件中设置了myapp.enabled属性,并且类路径上存在com.mysql.cj.jdbc.Driver类时才会被加载。

相关推荐
码到成功>_<6 分钟前
Spring Boot实现License生成和校验
数据库·spring boot·后端
尽兴-7 分钟前
Redis模拟延时队列 实现日程提醒
java·redis·java-rocketmq·mq
书埋不住我27 分钟前
java第三章
java·开发语言·servlet
boy快快长大29 分钟前
将大模型生成数据存入Excel,并用增量的方式存入Excel
java·数据库·excel
孟秋与你32 分钟前
【spring】spring单例模式与锁对象作用域的分析
java·spring·单例模式
菜菜-plus36 分钟前
java 设计模式 模板方法模式
java·设计模式·模板方法模式
萨达大37 分钟前
23种设计模式-模板方法(Template Method)设计模式
java·c++·设计模式·软考·模板方法模式·软件设计师·行为型设计模式
tian-ming38 分钟前
(十八)JavaWeb后端开发案例——会话/yml/过滤器/拦截器
java·开发语言·前端
不能只会打代码41 分钟前
大学课程项目中的记忆深刻 Bug —— 一次意外的数组越界
java·github·intellij-idea·话题博客
Ztiddler1 小时前
【npm设置代理-解决npm网络连接error network失败问题】
前端·后端·npm·node.js·vue