SpringBoot手写starter
相信大家在公司做项目时经常会使用到公司自己封装的依赖,里面就包括一些starter。可以用于制成通用方法以及框架等方便维护以及后续开发。所以研究了一下如何自己去写。先小试牛刀(在一个maven项目下快速两个创建springboot项目,一个用来写starter,一个用来测试。至于为什么这样建是因为,写完的starter需要打包然后配置下maven私库才能跨项目使用,所以现在同一个工程里做)
首先

创建完的项目就是这样子。stater的命名是有规范的,像官方的就是把自定义名字放在最后。非官方的就是放在最前面。
先不讲springboot源码了,感兴趣的可以自己去看看。先上代码:
service:
import lombok.AllArgsConstructor;
@AllArgsConstructor
public class SplicingService {
private String before;
private String after;
public String Splicing(String word)
{
return before+ word + after;
}
}
config:
import com.abc.splicingspringbootstater.Service.SplicingService;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
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;
import javax.annotation.Resource;
@Configuration
@ConditionalOnClass(SplicingService.class)
@EnableConfigurationProperties(SplicingServiceProperties.class)
public class SplicingAutoConfiguration {
@Resource
private SplicingServiceProperties properties;
@Bean
@ConditionalOnMissingBean()
public SplicingService splicingService() {
return new SplicingService(properties.getPrefix(), properties.getSuffix());
}
}
接下来就是Properties类:
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
@Data
@ConfigurationProperties(prefix = "splicing.service")
public class SplicingServiceProperties {
private String prefix;
private String suffix;
}
然后最关键的配置文件 spring.factories:

在resource下创建文件夹META-INF,在新建文件spring.factories
里面的内容就是 声明我们要自动配置的类(这些在源码中都可以看到)
org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.abc.splicingspringbootstater.config.SplicingAutoConfiguration
最后就是使用test项目来测一下,首先就是在yml里写上我们的配置
splicing:
service :
prefix : AAA
suffix : BBB
写一个controller 测试
import com.abc.splicingspringbootstater.Service.SplicingService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
@RestController
public class TestController {
@Resource
private SplicingService splicingService;
@RequestMapping("/test")
public String getNewChar(String word)
{
return splicingService.Splicing(word);
}
}
去网页测一下可以看到结果:

大功告成,我们在拓展一下,给这个字符串拼接加一个开关enabled true的时候拼,flase就不拼
改动starter的autoconfiguration:
import com.abc.splicingspringbootstater.Service.SplicingService;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
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;
import javax.annotation.Resource;
@Configuration
@ConditionalOnClass(SplicingService.class)
@EnableConfigurationProperties(SplicingServiceProperties.class)
public class SplicingAutoConfiguration {
@Resource
private SplicingServiceProperties properties;
@Bean
@ConditionalOnProperty(name = "splicing.service.enabled", havingValue = "true")
public SplicingService splicingService2() {
return new SplicingService(properties.getPrefix(), properties.getSuffix());
}
@Bean
@ConditionalOnMissingBean()
public SplicingService splicingService() {
return new SplicingService("", "");
}
}
如果说这个开关新方法你写在了最开始写下面,那么一定会报错,因为会出现两个实例。所以要把顺序调换一下,如果yml里enabled是true这样@ConditionalOnMissingBean()就会发现有实例而不在去新建,然后改一下yml再去网页试试:
splicing:
service :
enabled : false
prefix : AAA
suffix : BBB

可以看到没有拼接。至此我们的stater就成功了。不太理解的可以去看看源码(估计也看不懂- -),之后如果自己学的更厉害了,就可以写一些框架级别的依赖文件(安全类,拦截器啥的),在去放到私库里。共勉!
项目链接
https://github.com/ZfPx51/mystarter.git