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