摘要:背景学习的自动配置对于了解整个后端代码运行流程非常重要只有在了解是如何配置的情况下才能在项目的配置中不那么举步维艰假如我们编写了一个用于处理文件信息的工具类那么我们可以如下操作工具步骤创建一个普通的项目注意其中的和这两项将对应以后使用的依赖
背景
学习spring boot的自动配置对于了解整个后端代码运行流程非常重要,只有在了解spring boot是如何配置的情况下,才能在项目的配置中不那么举步维艰.
START假如我们编写了一个用于处理文件信息的工具类,那么我们可以如下操作
工具IntelliJ IDEA 2018
步骤注意其中的Group和Artifact,这两项将对应以后使用的依赖参数
xyz.crabapple begonia 0.0.1-SNAPSHOT
BegoniaApplication 为spring boot自己生成的入口类所在的java文件.
Tool 是我的工具类具体实现
public class Tool { public String prefix; public Tool(String prefix) { this.prefix = prefix; } /** * 计算时间戳 * @return 时间戳+五位随机大写字母 */ public String getStamp() { String prefix = String.valueOf(new Date().getTime()); prefix=prefix.substring(2,prefix.length()); char[] arr = new char[5]; Random random = new Random(); for (int i = 0; i < 5; i++) arr[i] = (char) (65 + random.nextInt(26)); String Suffix = String.valueOf(arr); return prefix + Suffix; }
ToolProperties充当配置类和application.properties的桥,即它从application.properties中取具体的配置信息,而真正的配置类需要再到ToolProperties去取.
@ConfigurationProperties(prefix = "Tool") public class ToolProperties { private String prefix; public String getPrefix() { return prefix; } public void setPrefix(String path) { this.prefix = path; } }
ToolAutoConfiguration是我的具体配置类
@Configuration @EnableConfigurationProperties(ToolProperties.class) @ConditionalOnClass(Tool.class) @ConditionalOnProperty(prefix = "Tool", name="open" ,havingValue="true") public class ToolAutoConfiguration { @Autowired ToolProperties toolProperties; @Bean public Tool autoConfiger(){ System.out.println("Tool工具已启动"); System.out.println(toolProperties.getPrefix()); return new Tool(toolProperties.getPrefix()); } }
1.@Configuration 表示这是一个配置类,作用等同于@Component.
以下三个注解都是条件注解,如果有一个不满足条件,自动配置就不会运行.
2.@EnableConfigurationProperties(ToolProperties.class)
表示配置类的自动配置必须要求ToolProperties.class的存在
3.@ConditionalOnClass(Tool.class)
要求功能类存在.
4.@ConditionalOnProperty(prefix = "Tool", name="open" ,havingValue="true")
查看@ConditionOnProperty
@Retention(RetentionPolicy.RUNTIME) @Target({ ElementType.TYPE, ElementType.METHOD }) @Documented @Conditional(OnPropertyCondition.class) public @interface ConditionalOnProperty { /** * Alias for {@link #name()}. * @return the names */ String[] value() default {}; /** * A prefix that should be applied to each property. The prefix automatically ends * with a dot if not specified. * @return the prefix */ String prefix() default ""; /** * The name of the properties to test. If a prefix has been defined, it is applied to * compute the full key of each property. For instance if the prefix is * {@code app.config} and one value is {@code my-value}, the fully key would be * {@code app.config.my-value} ** Use the dashed notation to specify each property, that is all lower case with a "-" * to separate words (e.g. {@code my-long-property}). * @return the names */ String[] name() default {}; /** * The string representation of the expected value for the properties. If not * specified, the property must not be equals to {@code false}. * @return the expected value */ String havingValue() default ""; /** * Specify if the condition should match if the property is not set. Defaults to * {@code false}. * @return if should match if the property is missing */ boolean matchIfMissing() default false; /** * If relaxed names should be checked. Defaults to {@code true}. * @return if relaxed names are used */ boolean relaxedNames() default true; }
prefix和name拼凑起来表示application.properties的配置信息key,例如我的配置信息为Tool.open=true,那么@ConditionalOnProperty(prefix = "Tool", name="open" ,havingValue="true")就表示配置信息中有这个key就为true,即满足条件,在此条件下若等于注解中havingValue的值,则该注解最终的结果为true.
最后我们需要注册自己的配置类在/src/main目录下创建META-INF目录,并其下创建spring.factories文件,其实spring.factories文件就是一个.properties文件.
新建好后,在其中按如下方式书写
org.springframework.boot.autoconfigure.EnableAutoConfiguration= xyz.crabapple.begonia.ToolAutoConfiguration
第一行的org.springframework.boot.autoconfigure.EnableAutoConfiguration就是一个key,第二行的xyz.crabapple.begonia.ToolAutoConfiguration就是我们的自动配置类,即value.配置类还可以按需添加.例如我们找一个依赖看一看
找到一个spring boot自带的依赖,可以看到其书写方式,供大家参考.
# Initializers org.springframework.context.ApplicationContextInitializer= org.springframework.boot.autoconfigure.SharedMetadataReaderFactoryContextInitializer, org.springframework.boot.autoconfigure.logging.AutoConfigurationReportLoggingInitializerEND
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/72958.html
摘要:简介简化应用开发的一个框架整个技术栈的一个大整合开发的一站式解决方案微服务,微服务架构风格服务微化一个应用应该是一组小型服务可以通过的方式进行互通单体应用微服务每一个功能元素最终都是一个可独立替换和独立升级的软件单元环境准备推荐及以上以上版 1、Spring Boot 简介简化Spring应用开发的一个框架; 整个Spring技术栈的一个大整合; J2EE开发的一站式解决方案; 2、微...
摘要:引入了新的环境和概要信息,是一种更揭秘与实战六消息队列篇掘金本文,讲解如何集成,实现消息队列。博客地址揭秘与实战二数据缓存篇掘金本文,讲解如何集成,实现缓存。 Spring Boot 揭秘与实战(九) 应用监控篇 - HTTP 健康监控 - 掘金Health 信息是从 ApplicationContext 中所有的 HealthIndicator 的 Bean 中收集的, Spring...
摘要:来源是最流行的用于开发微服务的框架。以下依次列出了最佳实践,排名不分先后。这非常有助于避免可怕的地狱。推荐使用构造函数注入这一条实践来自的项目负责人。保持业务逻辑免受代码侵入的一种方法是使用构造函数注入。 showImg(https://mmbiz.qpic.cn/mmbiz_jpg/R3InYSAIZkHQ40ly9Oztiart2lESCyjCH0JwFRp3oErlYobhibM...
摘要:代码如下所示自定义业务实现恒宇少年码云消息内容是否显示消息内容,我们内的代码比较简单,根据属性参数进行返回格式化后的字符串。 在我们学习SpringBoot时都已经了解到starter是SpringBoot的核心组成部分,SpringBoot为我们提供了尽可能完善的封装,提供了一系列的自动化配置的starter插件,我们在使用spring-boot-starter-web时只需要在po...
时间:2017年12月01日星期五说明:本文部分内容均来自慕课网。@慕课网:http://www.imooc.com 教学源码:无 学习源码:https://github.com/zccodere/s... 第一章:课程介绍 1-1 课程介绍 热部署的使用场景 本地调式 线上发布 热部署的使用优点 无论本地还是线上,都适用 无需重启服务器:提高开发、调式效率、提升发布、运维效率、降低运维成本 前置...
阅读 2347·2019-08-30 15:56
阅读 995·2019-08-30 15:55
阅读 3185·2019-08-30 15:44
阅读 919·2019-08-30 10:53
阅读 1848·2019-08-29 16:33
阅读 2411·2019-08-29 16:13
阅读 696·2019-08-29 12:41
阅读 851·2019-08-26 13:56