1、说明

启动器模块是一个 空 jar 文件,仅提供辅助性依赖管理,这些依赖可能用于自动装配或者其他类库;

命名规约:

官方命名:

  • 前缀spring-boot-starter-xxx
  • 比如:spring-boot-starter-web…

自定义命名:

  • xxx-spring-boot-starter
  • 比如:mybatis-spring-boot-starter

2、编写启动器

1)新建一个空项目

springboot 指定启动名称 springboot自定义启动类_自定义

  • 项目建成后选择jdk版本

springboot 指定启动名称 springboot自定义启动类_自定义_02

2)新建一个普通Maven模块

tuwer-spring-boot-starter 这就是自定义启动器的名称,别处引用时就用这个名称

springboot 指定启动名称 springboot自定义启动类_spring_03

springboot 指定启动名称 springboot自定义启动类_spring_04

springboot 指定启动名称 springboot自定义启动类_java_05

3)新建一个Springboot模块

springboot 指定启动名称 springboot自定义启动类_自定义_06

4)基本结构

springboot 指定启动名称 springboot自定义启动类_java_07

5)模块绑定

在普通Maven模块中加Springboot模块的依赖

<dependency>
    <groupId>com.tuwer</groupId>
    <artifactId>tuwer-spring-boot-starter-autoconfigure</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</dependency>

springboot 指定启动名称 springboot自定义启动类_spring boot_08

6)清理Springboot模块

为保持项目干净,建议删除多余部分;不删也能使用

springboot 指定启动名称 springboot自定义启动类_spring_09

spring-boot-starter 是所有 starter 的基础依赖,必须要有

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
</dependency>

7)编写自已的服务

在SpringBoot模块中编写自已的服务类

public class HelloService {
    /**
     * 配置属性
     */
    HelloProperties helloProperties;

    public HelloProperties getHelloProperties() {
        return helloProperties;
    }

    public void setHelloProperties(HelloProperties helloProperties) {
        this.helloProperties = helloProperties;
    }

    public String sayHello(String name){
        return helloProperties.getPrefix() + name + helloProperties.getSuffix();
    }
}

8)编写属性配置类

如果不需要调用方配置属性的话,可以省略

@ConfigurationProperties(prefix = "tuwer.hello") // 指明这是属性配置类
public class HelloProperties {
    /**
     * 前缀
     */
    private String prefix;
    /**
     * 后缀
     */
    private String suffix;

    public String getPrefix() {
        return prefix;
    }

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

    public String getSuffix() {
        return suffix;
    }

    public void setSuffix(String suffix) {
        this.suffix = suffix;
    }
}

9)编写自动配置类

指明自已的服务类在什么情况下生效,满足生效条件时,自动注入到Spring容器中,供调用方使用

@Configuration // 自动配置类
@ConditionalOnWebApplication // 是web应用时生效
@EnableConfigurationProperties(HelloProperties.class) // 指明属性配置类HelloProperties
public class HelloServiceAutoConfiguration {

    /**
     * 注入属性配置类
     */
    @Autowired
    HelloProperties helloProperties;

    /**
     * 生成服务类,注入到容器中
     * @return
     */
    @Bean
    public HelloService getHelloService(){
        HelloService helloService = new HelloService();
        // 设置属性
        helloService.setHelloProperties(helloProperties);
        return helloService;
    }

}

10)编写spring.factories

指明自动配置类的地址

resources 目录下编写一个自己的 META-INF\spring.factories

org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.tuwer.config.HelloServiceAutoConfiguration
  • 目录结构

springboot 指定启动名称 springboot自定义启动类_spring boot_10

11)Install到仓库

安装到maven本地仓库中

springboot 指定启动名称 springboot自定义启动类_spring_11

springboot 指定启动名称 springboot自定义启动类_java_12

3、测试启动器

1)新建一个SpringBoot 项目

2)导入自己的启动器

<dependency>
    <groupId>com.tuwer</groupId>
    <artifactId>tuwer-spring-boot-starter</artifactId>
    <version>1.0-SNAPSHOT</version>
</dependency>

3)编写 HelloController

@RestController
public class HelloController {
    @Autowired
    HelloService helloService;

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

4)编写配置文件 application.properties

tuwer.hello.prefix=1111111 
tuwer.hello.suffix=2222222

5)启动测试

springboot 指定启动名称 springboot自定义启动类_java_13

  • 不配置属性

springboot 指定启动名称 springboot自定义启动类_java_14

可以在HelloProperties中指明默认值为空

4、自定义日志拦截启动器

  • 视频地址:https://www.bilibili.com/video/BV16q4y1q71D
  • 源码:https://gitee.com/tuwer/mylog-spring-boot-starter

springboot 指定启动名称 springboot自定义启动类_java_15