美文网首页Java
编写一个springboot starter

编写一个springboot starter

作者: lfboo | 来源:发表于2021-10-25 21:46 被阅读0次
    编写starter步骤
    1. 创建名字为 xxx-spring-boot-starter 的启动器项目
    2. 创建名字为 xxx-spring-boot-autoconfigure的项目
      • 编写属性绑定类 xxxProperties
      • 编写服务类,引入 xxxProperties
      • 编写自动配置类XXXAutoConfiguration注入配置
      • 创建 spring.factories 文件,用于指定要自动配置的类
    3. 启动器项目为空项目,用来引入 xxx-spring-boot-autoconfigure等其他依赖
    4. 项目引入 starter,配置需要配置的信息
    创建启动器项目

    由于启动器不需要代码实现,只需要依赖其他项目,所以直接创建一个空的 maven 项目。但是名字要规范。
    这里创建的 startermyapp-spring-boot-starter

    image.png
    pom 文件非常简单,只需要引入接下来要创建的 myapp-spring-boot-autoconfigure.
    <?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>
    
        <groupId>net.codingme.starter</groupId>
        <artifactId>myapp-spring-boot-starter</artifactId>
        <version>1.0-SNAPSHOT</version>
        <!-- 启动器 -->
        <dependencies>
            <!--  引入自动配置项目 -->
            <dependency>
                <groupId>net.codingme.starter</groupId>
                <artifactId>myapp-spring-boot-autoconfigure</artifactId>
                <version>0.0.1-SNAPSHOT</version>
            </dependency>
        </dependencies>
    </project>
    
    创建自动配置项目

    结合上面对 starter 的分析,直接创建一个名字为 myapp-spring-boot-autoconfigure 的项目。项目中只引入 springboot 父项目以及 spring-boot-starter。

    <?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.2.0.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>net.codingme.starter</groupId>
        <artifactId>myapp-spring-boot-autoconfigure</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>myapp-spring-boot-autoconfigure</name>
        <description>Demo project for Spring Boot</description>
        <properties>
            <java.version>1.8</java.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter</artifactId>
            </dependency>
        </dependencies>
    </project>
    

    项目的总体结构如图:


    image.png

    在 HelloProperties中通过注解 @ConfigurationProperties(prefix = "myapp.hello")让类中的属性与 myapp.hello开头的配置进行绑定。

    @ConfigurationProperties(prefix = "myapp.hello")
    public class HelloProperties {
    
        private String suffix;
    
        public String getSuffix() {
            return suffix;
        }
    
        public void setSuffix(String suffix) {
            this.suffix = suffix;
        }
    }
    

    然后在 HelloService中的 sayHello方法使用 HelloProperties 中自动绑定的值

    public class HelloService {
        HelloProperties helloProperties;
        
        public String sayHello(String name) {
            return "Hello " + name + "," + helloProperties.getSuffix();
        }
        
        public HelloProperties getHelloProperties() {
            return helloProperties;
        }
    
        public void setHelloProperties(HelloProperties helloProperties) {
            this.helloProperties = helloProperties;
        }
    }
    

    为了让 HelloService 可以自动注入且能正常使用 HelloProperties,所以我们在
    HelloServiceAutoConfiguration 类中把 HelloProperties.class 引入,然后把 HelloService 注入到 Bean。

    /**
     * web应用才生效
     */
    @ConditionalOnWebApplication
    /**
     * 让属性文件生效
     */
    @EnableConfigurationProperties(HelloProperties.class)
    /***
     * 声明是一个配置类
     */
    @Configuration
    public class HelloServiceAutoConfiguration {
    
        @Autowired
        private HelloProperties helloProperties;
    
        @Bean
        public HelloService helloService() {
            HelloService helloService = new HelloService();
            helloService.setHelloProperties(helloProperties);
            return helloService;
        }
    }
    

    最后在 spring.factories中只需要指定要自动配置的类即可。

    # Auto Configure
    org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
    net.codingme.starter.HelloServiceAutoConfiguration
    

    到这里,自动配置项目就完成了。可以在 myapp-spring-boot-autoconfigure项目执行 mvn install 把自动配置项目打包到本地仓库,然后使用相同的命令把 myapp-spring-boot-starter 安装到仓库。因为后者依赖于前者项目,所以这里前者需要先进 mvn install

    使用自定义的启动器

    创建一个 springboot项目myapp-spring-boot-starter-test。


    image.png

    引入 web 依赖,引入自己编写的 myapp-spring-boot-starter.

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    
    <!-- 引入自己的 starter -->
    <dependency>
        <groupId>net.codingme.starter</groupId>
        <artifactId>myapp-spring-boot-starter</artifactId>
        <version>1.0-SNAPSHOT</version>
    </dependency>
    

    编写一个 HelloController 注入自动配置里的 HelloService用于测试。

    @RestController
    public class HelloController {
    
        @Autowired
        HelloService helloService;
    
        @GetMapping("/hello")
        public String sayHello(String name) {
            return helloService.sayHello(name);
        }
    }
    

    由于 autoConfigure 项目中定义了 sayHello 方法会输出“Hello”+传入的 name + 配置的 hello.suffix,所以我们在 springboot 配置文件中配置这个属性

    相关文章

      网友评论

        本文标题:编写一个springboot starter

        本文链接:https://www.haomeiwen.com/subject/rrnyaltx.html