SpringBoot自定义starters

SpringBoot自定义startersSpringBoot 自定义 starters 1 简介 2 如何自定义 starter 2 1 编写自定义模块 2 1 1 一个父模块和两个子模块 2 1 2 写上相应的配置类等等 2 1 3 定义 spring factories 2 1 4 依次打包 2 1 5 使用其它模块进行调用 1 简介 SpringBoot 最强大的功能就是把我们常用的场景抽象成一个个 starter 场景启动器

SpringBoot自定义starters

1、简介

2、如何自定义starter

2.1、编写自定义模块

2.1.1、一个父模块和两个子模块

2.1.2、写上相应的配置类等等

2.1.3、定义spring.factories

2.1.4、依次打包

2.1.5、使用其它模块进行调用

1、简介

SpringBoot最强大的功能就是把我们常用的场景抽象成一个个starter(场景启动器),我们通过引入springBoot为我们提供这些场景启动器,我们再进行少量的配置就能使用相应的功能。但是,SpringBoot不能包含所有的场景,经常需要我们自定义starter,来简化我们对springBoot的使用。

2、如何自定义starter

2.1、编写自定义模块

根据SpringBoot官方的介绍,一般情况下我们需要创建两个模块,一个是autoconfigure,一个是starter,autoconfigure里面装着自定义配置类,而starter只是负责向外提供调用的接口,所以下面我们先创建了几个模块

2.1.1、一个父模块和两个子模块

SpringBoot创建父子级Maven项目

2、创建完成之后,我们需要在starter的pom文件中引入autoconfigure,又因为我们这个是以web首页为例子,所以还要在autoconfigure里面引入web的starter启动器。

pom

starter的pom文件:




springboot_custom_starter
cool.ale
0.0.1-SNAPSHOT

4.0.0

自定义启动器starter

dujlc-spring-boot-starter



cool.ale
0.0.1-SNAPSHOT
dujlc-spring-boot-autoconfigure



autoconfigure的pom文件:




springboot_custom_starter
cool.ale
0.0.1-SNAPSHOT

4.0.0
dujlc-spring-boot-autoconfigure


org.springframework.boot
spring-boot-starter-web



org.springframework.boot
spring-boot-configuration-processor
true


/pre>

h4>2.1.2、写上相应的配置类等等

/h4>

blockquote>一共涉及到三个Java类


/blockquote>

table border='1' style='border-collapse: collapse; width: 100%;'>

类名称含义HelloAutoConfiguration自动配置类,可调用我们自动配置实现的具体功能HelloProperties自动配置属性文件,配置着我们的这个自动配置可设置哪些属性IndexControllerHelloAutoConfiguration 调用的具体实现

/table>

blockquote>代码举例如下:


/blockquote>

p>HelloAutoConfiguration

/p>

pre class='language-javascript'>

package com.starter.ale;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
// 必须要配置这个属性才会生效
@ConditionalOnProperty("cool.ale.starter.name")
@EnableConfigurationProperties(HelloProperties.class)
public class HelloAutoConfiguration {

@Autowired
private HelloProperties helloProperties;
/** * 为web应用添加一个首页 */
@Bean
public IndexController indexController(){

return new IndexController(helloProperties);
}
}

/pre>

p>HelloProperties

/p>

pre class='language-javascript'>

package com.starter.ale;
import org.springframework.boot.context.properties.ConfigurationProperties;
@ConfigurationProperties("cool.ale.starter")
public class HelloProperties {

private String name;
public String getName() {

return name;
}
public void setName(String name) {

this.name = name;
}
}

/pre>

p>IndexController

/p>

pre class='language-javascript'>

package com.starter.ale;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class IndexController {

HelloProperties helloProperties;
public IndexController() {
}
public IndexController(HelloProperties helloProperties) {

this.helloProperties = helloProperties;
}
/** * 首页 * @return */
@RequestMapping("/")
public String index(){

return helloProperties.getName() + "欢迎你";
}
}

/pre>

blockquote>在这里我们发现一个问题,就是HelloProperties类里面的注解报错,我们需要做如下操作:


/blockquote>

blockquote>我们发现勾选之后还报错,这个其实已经和编码没有关系了,只是一个提示,我们可以通过下面的方法让报错不提示:


/blockquote>

blockquote>在报错行上alt+enter键,弹出如下图所示框,依次选中即可(先忽略图中代码,这是我从另一个项目截的图),原来的代码是第二张图的@ConfigurationProperties报错:


/blockquote>

h4>2.1.3、定义spring.factories

/h4>

blockquote>定义这个文件的目的就是让SpringBoot找到我们的自定义的自动配置类,如下所示:


/blockquote>

pre class='language-javascript'>

# Auto Configure
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
com.starter.ale.HelloAutoConfiguration

/pre>

h4>2.1.4、依次打包

/h4>

blockquote>代码书写完之后,我们将这三个打包,一定要注意打包顺序,starter在最后打包,依次点击三个包的install,如下图所示:


/blockquote>

h4>2.1.5、使用其它模块进行调用

/h4>

blockquote>1、在其它模块中的全局配置文件中配置下面属性:


/blockquote>

pre class='language-javascript'>

cool.ale.starter.name="ale"

/pre>

blockquote>2、启动首页访问,如下图所示:


/blockquote>

编程小号
上一篇 2025-03-10 15:30
下一篇 2025-02-22 14:01

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/146873.html