首页 > 其他分享 >SpringBoot自定义starter

SpringBoot自定义starter

时间:2023-01-16 23:11:14浏览次数:44  
标签:SpringBoot 自定义 boot springframework smy import org starter

SpringBoot自定义starter

目录

1 自定义starter

1.1 新建project和Module

1 新建一个空project

image-20230116223014911

image-20230116223044606

2 新建两个Maven Module,一个是自定义的starter提供者(smy-starter-provider),一个是starter的使用者(smy-starter-user)。

image-20230116223212682

1.2 对于starter-provider

对于starter提供者,作如下配置 pom,java文件,factories

该Module的文件结构如下,

image-20230116224002815

pom.xml文件

<?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,里面有许多依赖的版本 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-parent</artifactId>
        <version>2.2.6.RELEASE</version>
    </parent>
    <groupId>org.example</groupId>
    <artifactId>smy-starter-provider</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-autoconfigure</artifactId>
        </dependency>
        <!--支持ConfigurationProperties-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-configuration-processor</artifactId>
            <optional>true</optional>
        </dependency>
        <!--lombok依赖,简化代码-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
    </dependencies>
</project>

属性配置类,HelloProperties.java

package com.smy;

import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;

/**
 * 属性配置类,相当于一个实体类,作用就是接收参数
 * 封装这个对象的过程是SpringBoot做的
 */
@Data
@ConfigurationProperties(prefix = "hello")
public class HelloProperties {
    private String name;
    private String age;
}

HelloService.java

package com.smy;

public class HelloService {
    private String name;
    private String age;

    public HelloService (String name, String age){
        this.name = name;
        this.age = age;
    }

    public String sayHello (){
        return "hello ==== 姓名:" + this.name + "--- age:" + age;
    }
}

HelloServiceAutoConfigration.java,作用相当于Spring xml配置中的 标签。

package com.smy;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * 自动配置类,用于自动配置HelloService对象
 *
 */
@Configuration
@EnableConfigurationProperties(HelloProperties.class) // 表示使用Springboot自动装配 HelloProperties,这个属性配置类

public class HelloServiceAutoConfigration {
    // 自动注入这个属性类,通过属性类 获得 属性值
    @Autowired
    private HelloProperties helloProperties;

    @Bean
    @ConditionalOnMissingBean // 当没有这个类型的bean时,才会注入
    public HelloService helloService() {
        return new HelloService(helloProperties.getName(), helloProperties.getAge());
    }
}

spring.factories

org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.smy.HelloServiceAutoConfigration

1.3 install

通过执行starter提供者的install,将jar包安装到本地maven仓库,方便之后的引用。

image-20230116224835359

1.4 对于starter-user

对于starter使用者,做如下测试,java文件,yml文件

该Module的目录结构如下,

image-20230116224151493

配置starter的属性,application.yml

server:
  port: 8080
hello:
  age: 111
  name: xiaoming

HelloController.java

package com.smy.controller;

import com.smy.HelloService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping
public class HelloController {
    @Autowired
    private HelloService helloService;

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

启动类,Application.java

package com.smy;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

1.5 测试

SpringBoot项目启动成功后,访问 http://localhost:8080/hello ,如果

image-20230116224451264

则证明成功。

2 执行流程

  1. 我们的SpringBoot项目,通过Application.java的主函数启动,而主函数是使用注解 @SpringBootApplication 修饰的,而 @SpringBootApplication 是一个复合注解,复合注解的其中一个是 @EnableAutoConfiguration

  2. @EnableAutoConfiguration 表示启用自动配置。 @EnableAutoConfiguration 也是一个复合注解,复合注解的其中一个是@Import({AutoConfigurationImportSelector.class})

  3. @Import({AutoConfigurationImportSelector.class}) 表示将类交给Spring容器实例化。而 AutoConfigurationImportSelector (自动配置导入选择器)这个类,会扫描所有依赖的jar包下是否存在META-INF/spring.factories文件

  4. META-INF/spring.factories文件是固定写法。在里面配置需要自动配置的类。通过

    org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.smy.HelloServiceAutoConfigration
    

    通过全类名com.smy.HelloServiceAutoConfigration来找到哪个类需要自动配置。

  5. HelloServiceAutoConfigration类中,一般使用 @Configuration@EnableConfigurationProperties(xxx.class) 修饰。里面的方法,使用 @Bean 修饰,起到Spring中标签的作用。而 @EnableConfigurationProperties(xxx.class) ,表示开启配置属性,即通过读取yml文件配置xxx.class的实例对象。

  6. 这就是starter自动配置的大致过程。结果看起来是,springboot读取我们自定义的yml文件,初始化化实例,并交给Spring容器管理。

标签:SpringBoot,自定义,boot,springframework,smy,import,org,starter
From: https://www.cnblogs.com/Sun-yuan/p/17056663.html

相关文章

  • 230116_50_SpringBoot入门
    指定自定义的配置文件bill.propertiesbill.properitesname=billage=11happy=falsebirth=2021/12/2通过@PropertySource注解指定自定义的配置文件@PropertyS......
  • 写一个 Hello SpringBoot2 项目
     项目目录:helloSpringBoot2、MainApplication、pom.xml  helloSpringBoot2逻辑类,标记@RestController/*@RestController的作用等同于@Controller+@ResponseB......
  • yml文件配置了但是springboot读不到yml的内容的问题(已解决)
    在写项目时可能误操作加了这一句代码,结果就导致了系统读不到yml配置解决方法:删除pom.xml中的<packagin>pom</packagin>或者尝试 https://blog.csdn.net/qq_41555595/art......
  • js文件下载自定义命名
    js下载文件时,如果下载地址文件名与实际名称不一致,需要自定义命名,使用a链接时如果涉及跨域,download属性不生效,解决方法:通过axios请求文件,创建a链接下载即可。axios.get(fi......
  • Django rest_framework 自定义捕获数据库错误
    自定义捕获错误fromdjango.dbimportDatabaseErrorfromrest_frameworkimportstatusfromrest_framework.responseimportResponsefromrest_framework.viewsimp......
  • MySQL自定义排序ORDER BY FIELD
    在一些场景中,有场景A查询出一个已经排好顺序的id,需要到场景B中查询这些,使用mysql中的WHERE**IN(****),查询出来的结果并不是按照传入的list排序的.但是......
  • springboot返回json和xml
    在项目中某些情况下接口需要返回的是xml数据或者json数据1、在springboot项目加入依赖jackson-dataformat-xml<dependency><groupId>com.fasterxml.jacks......
  • springboot的定时任务
    1、定时任务的创建方式:基于注解@Schedule和@EnableScheduling(待完善。。。)2、@Schedule和@EnableScheduling适用于定时任务执行时间较短,并且比较单......
  • SpringBoot集成Thymeleaf
    1、引入依赖在maven项目的pom.xml中引入spingboot-boot-starter-thymeleaf依赖,同时为了解决Html严格校验报错的问题,增加nekohtml依赖<!--thymeleaf模板引擎-->......
  • 「HTML+CSS」自定义加载动画【049】
    前言Hello!小伙伴!首先非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出~哈哈自我介绍一下昵称:海轰标签:程序猿一只|C++选手|学生简介:因C语言结识编程,随后转入计算......