手撸了一个starter,同事直夸我666~
Spring Boot starter原理
Spring Boot 将常见的开发功能,分成了一个个的starter,这样我们开发功能的时候只需要引入对应的starter,而不需要去引入一堆依赖了!starter可以理解为一个依赖组,其主要功能就是完成引入依赖和初始化配置。Spring 官方提供的starter 命名规范为 spring-boot-starter-xxx
,第三方提供的starter命名规范为 xxx-spring-boot-starter
。
这里我们以 RocketMQ
的依赖 rocketmq-spring-boot-starter
来学习 starter的原理。
在项目中引入 rocketmq-spring-boot-starter
之后,实际上就引入了 rocketmq
的一些相关依赖。
在 rocketmq-spring-boot
中有一个自动装配的类RocketMQAutoConfiguration
,我截取了其中的一小段代码,一起来看看。
@Configuration @EnableConfigurationProperties(RocketMQProperties.class) @ConditionalOnClass({MQAdmin.class}) @ConditionalOnProperty(prefix = "rocketmq", value = "name-server", matchIfMissing = true) @Import({MessageConverterConfiguration.class, ListenerContainerConfiguration.class, ExtProducerResetConfiguration.class, RocketMQTransactionConfiguration.class}) @AutoConfigureAfter({MessageConverterConfiguration.class}) @AutoConfigureBefore({RocketMQTransactionConfiguration.class}) public class RocketMQAutoConfiguration { private static final Logger log = LoggerFactory.getLogger(RocketMQAutoConfiguration.class); public static final String ROCKETMQ_TEMPLATE_DEFAULT_GLOBAL_NAME = "rocketMQTemplate"; @Autowired private Environment environment; @Bean(destroyMethod = "destroy") @ConditionalOnBean(DefaultMQProducer.class) @ConditionalOnMissingBean(name = ROCKETMQ_TEMPLATE_DEFAULT_GLOBAL_NAME) public RocketMQTemplate rocketMQTemplate(DefaultMQProducer mqProducer, RocketMQMessageConverter rocketMQMessageConverter) { RocketMQTemplate rocketMQTemplate = new RocketMQTemplate(); rocketMQTemplate.setProducer(mqProducer); rocketMQTemplate.setMessageConverter(rocketMQMessageConverter.getMessageConverter()); return rocketMQTemplate; } }
- @Configuration 说明这是一个配置类,类中被@Bean注解了的方法,就是spring的一个bean,例如
rocketMQTemplate
。 - @EnableConfigurationProperties,启用被@ConfigurationProperties的bean,这里引入了
RocketMQProperties
。
RocketMQProperties
就是需要在yml文件中写入的属性。
@ConfigurationProperties(prefix = "rocketmq") public class RocketMQProperties { private String nameServer; private String accessChannel; private Producer producer; private Consumer consumer = new Consumer(); }
在Spring Boot项目启动的时候默认只会扫描下级目录下带 @Configuration
注解的类,那么像本文中提到的 RocketMQAutoConfiguration
是如何扫描的呢?其实项目启动的时候会去加载项目中所有的 spring.factories
文件,然后加载对应的配置类,因此我们就需要在 spring.factories
中只指定需要扫描的类。
原理搞明白了,接下来我们就简单实现一个自己的starter!这个starter的主要作用就是给一个对象尾部拼接一个字符串!
一、新建项目
新建一个名为 javatip-spring-boot-starter
的项目,并且引入下面的依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency>
二、新增配置类
配置类对应的properties文件中的属性为javatip.name
;
@ConfigurationProperties(prefix = "javatip") public class JavatipPorperties { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } }
三、新增拼接字符串的方法
此方法主要就是为对象拼接一个固定的字符串
public class StrUt { private String name; public String strTo(Object object){ return object +"---"+ getName(); } public String getName() { return name; } public void setName(String name) { this.name = name; } }
四、新增自动配置类
使用注解 @EnableConfigurationProperties
启用 JavatipProperties
配置类
使用注解 @Configuration
配合 @Bean
注册一个拼接字符串的bean对象。
@Configuration @EnableConfigurationProperties(JavatipPorperties.class) public class JavatipAutoConfiguration { @Autowired private JavatipPorperties javatipPorperties; @Bean public StrUt strut(){ StrUt strut = new StrUt(); strut.setName(javatipPorperties.getName()); return strut; } }
五、新增配置发现文件
在resources文件夹中新建 META-INF
文件夹,在 META-INF
文件夹中新建配置发现文件 spring.factories
,并且将自动配置类写到文件里。
org.springframework.boot.autoconfigure.EnableAutoConfiguration=com.javatip.str.configuration.JavatipAutoConfiguration
六、打包测试
使用 mvn install
命令将项目打包推送到本地maven仓库,然后新建一个测试项目,引入打包好的依赖。
<dependency> <groupId>com.javatip</groupId> <artifactId>javatip-spring-boot-starter</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency>
在 application.yml
文件中写入自动拼接的字符串对应的属性 javatip.name
。
javatip: name: Java旅途
然后手写一个测试类:
@RestController public class Test { @Autowired private StrUt strUt; @GetMapping("test") public String test(){ String str = strUt.strTo("who are you?"); return str; } }
运行测试类后,页面返回了
who are you?---Java旅途
这样,一个简单的starter就写好了,只要理解了starter的原理,实现起来就很简单,第一点就是starter相当于一个依赖组,另一点就是starter可以完成初始化配置。
点关注、不迷路
如果觉得文章不错,欢迎关注、点赞、收藏,你们的支持是我创作的动力,感谢大家。
如果文章写的有问题,请不要吝惜文笔,欢迎留言指出,我会及时核查修改。
如果你还想看到更多别的东西,可以微信搜索「Java旅途」进行关注。回复“手册”领取Java面试手册!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
鸿蒙内核源码分析(静态站点篇) | 五一哪也没去就干了这事 | 百篇博客分析HarmonyOS源码 | v52.01
OpenHarmony开发者文档 国内访问 : https://openharmony.21cloudbox.com/ 国外访问 : https://openharmony.github.io/ 先看图: 在给鸿蒙内核加注和写博客期间需要不断的查找资料,觉得官方目前资料展示方式并不能满足自己的需求,浪费了很多宝贵的时间,所以在想能不能将官方文档整个静态站点出来即方便别人更方便自己,这是一劳永逸,利己利他的事干嘛不做的,刚好五一有成块的时间,本来也想出去走走,结果却哪都没去,期间遇到不少问题,但基本都解决了,有段时间没更新博客了但换来未来的一片爽朗之声, hin 值得! 这里必须要感谢下这套主体的作者 Mr.hope ,人非常的nice, 晚上12点我们还在一起解决问题.再次感谢!!! 主题地址:vuepress-theme-hope 有兴趣的可以去了解下,一个功能强大的 vuepress 主题. 静态站点将每月同步官方文档,静态站点仓库已经开放,仓库地址 欢迎拿去部署. 侧边栏 这个不用说,都恨不得多开几个屏幕,技术人没它真不行,虽用谁知道,侧边栏是按官方的目录结构来的,但目前不是最优...
- 下一篇
详解 WebRTC 传输安全机制:一文读懂 DTLS 协议
作者|进学 审校|泰一 DTLS (Datagram Transport Layer Security) 基于 UDP 场景下数据包可能丢失或重新排序的现实情况下,为 UDP 定制和改进的 TLS 协议。在 WebRTC 中使用 DTLS 的地方包括两部分:协商和管理 SRTP 密钥和为 DataChannel 提供加密通道。 本文结合实际数据包分析 WebRTC 使用 DTLS 进行 SRTP 密钥协商的流程。并对在实际项目中使用 DTLS 遇到的问题进行总结。 DTLS 协议简介 在分析 DTLS 在 WebRTC 中的应用之前,先介绍下 DTLS 协议的基本原理。DTLS 协议由两层组成: Record 协议 和 Handshake 协议 Record 协议:使用对称密钥对传输数据进行加密,并使用 HMAC 对数据进行完整性校验,实现了数据的安全传输。 Handshake 协议:使用非对称加密算法,完成 Record 协议使用的对称密钥的协商。 HandShake TLS 握手协议流程如下,参考 RFC5246 DTLS 握手协议流程如下,参考 RFC6347 TLS 和 DTL...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8安装Docker,最新的服务器搭配容器使用
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8编译安装MySQL8.0.19
- CentOS7,CentOS8安装Elasticsearch6.8.6
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池