我们最早配置spring应用的时(🎱)候,必须要经历的步骤:1.pom文件中引入相关的jar包,包(🦊)括spring,redis,jdbc等等 2.通过properties或者xml配置相(📮)关的信息 3.不断调试直到可以使用。 问题:(🎤)时间长,复杂,同时在写下一个项目(🚽)的时候大概率要经过相同的模式配置才(🌛)能(🥠)达到可以使用的状态。同时在众多的(🧓)jar中,我(🍜)们需要相互配置依赖间的版本关系,十分的(🗜)复杂 原始版本:(😾) 我们就想到能不能把这些jdbc整(💄)合起来,类似于深度学习中(🌫)anaconda下载依赖一样去管理,依赖间的关系不需要我们去负责,而是交给(♓)spring去管理。 starter版本(🚎): 我(🎨)们可以将starter包看作是一个包装箱,把(😅)复(🤥)杂的事情都交给了spring负责,官方(🌻)维护starter包会导入的东西。而我们只需要知道那个starter包是有什么用处,例如:spring-boot-starter-web是负责spring web项目的依赖。 starter文件也只是一个(🔳)pom文件,而不是jar,它(🛌)的目的也是去自动的引入其他的jar文件,上图展示的spring-boot-starter-web中的依赖就有spring-boot-starter。 starter只是一(🐰)个pom文件 下面也就(🗡)是starter的关键所在,请问我们为什么引入了starter之后只需要配置一(🤮)点点的个性化设置,例如创建application.properties仅仅配置端口(🌝)等等就可以完成启动应用?是谁帮助我们配置了其他复杂的信息? 引出自动配置 自动配置主要通过xxxAutoConfiguration这些类来实现,我们查找一个这样的类来进行示例演示 上图是DataSourceAutoConfiguration这个自动配置类,我们可以看到(🐽)类上的几个注解。 我们点击@EnableConfiguration注解中的@DataSourceProperties进去查看 可以查看(🙍)到这里使用@configurationPropertes,@ConfigurationProperties注解的作用是把(😠)yml或(🕉)者properties配(🥛)置文件转化为bean。 同时这里也设置了prefix前缀,在我们(🖇)项目的application.properties中(🖊)配置的时候(🌖),提示的就是这些bean实例中的属(🖐)性。 所以是使用@ConfigurationProperties和@EnableConfigurationProperties这(🐴)两个注解来完成将一个包含众多属性的类来注(🔎)册成为可供(🏪)springIoc容器管理的bean。 而这个bean的注册过程是在各个XXXAutoConfiguration类中完成的。 我们都知道(🐍)springboot默认扫描(🚽)启动类下面的主类和子类的bean来完成注解,但是并没有包括依赖包中的类(❇),那么依赖包中的bean是如何被发现和加载的(🍱)? 关键在于@SpringBootApplication这个注解 注解层次: 注解层次图示: 如果要让一个普通类(👸)交给Spring容器管理,通常(🗡)有以下方法: springboot中使用了@Import 方法 @EnableAutoConfiguration注解(😦)中使用了(❤)@Import({AutoConfigurationImportSelector.class})注解,AutoConfigurationImportSelector实(🥈)现了DeferredImportSelector接口, DeferredImportSelector接口继承了ImportSelector接(🌕)口,ImportSelector接口只有一个selectImports方法。 selectImports方法返回一组bean,@EnableAutoConfiguration注解借助@Import注解将这组bean注(🕔)入到spring容器中,springboot正式通过这种机制来完成bean的注入的。 关于@import注解(🆔)的加载可以查看(📜)这个文章(🧢):https://zhuanlan.zhihu.com/p/147025312 ps:晕乎乎的,我只看懂(✉)了一部分。 加载redisAutoConfiguration的流(🐖)程图示 下面我们演示自定义starter的(♿)流程: 我们确定(🤭)好自定义starter的GAV(groupId,ArtifactId,Version),这里需要注意的是ArtifactId的命名,对于spring进行管理的starter包,命名规则是:spring-boot-starter-xxx,而为了区别spring进行管理的starter包,自定义的starter包一般命名规则是:xxx-spring-boot-starter,例如mybatis官方推出的starter包:mybatis-spring-boot-starter。 groupId使用自己(🖇)域名的反写即可。 项目结构如下: 依赖:spring-boot-configuration-processor 作用(🎊):导入之后会自动生成元数据(meta-data),在application.properties配置的时候会有提示。 例如: 由于是自动生成,在你配置了@ConfigurationProperties之后就(🏀)会自动生成元数据,在你写application.properties的时候就会进行自动提示。 当无法提示的时候多次clean,之后再compile然后在install发布。 具体可以看这个博(🚆)客 https://blog.csdn.net/wangleleb/article/details/104904348 依赖(😿): spring-boot-starter 作用:是为了使用前面提到的自动配置的注解。注解@ConfigurationProperties和@EnableConfigurationProperties两个(🥂)注解都在spring-boot-context包中 编写自动配置(⚾)类代码: 编写service代码: 编写config类: 关于这里@ConditionOnProperty这个注解,该注解(😾)的大概含义就是,对于前缀是demo的属性,底下的值isopen为true时候,该自动配置(🎬)类才会生效。 编写spring.factories 将key:EnableAutoConfiguration-->DemoConfig这个类 使用maven命令:mvn clean compile install 清理,编译,发布到本地仓库中去 配置资源文件 随便编写一个类验证 结果<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
二.starter内部详情 <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <version>2.7.3</version> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> <version>2.7.1</version> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.24</version> </dependency> </dependencies>
package properties; import lombok.Getter;import lombok.Setter;import org.springframework.boot.context.properties.ConfigurationProperties; @ConfigurationProperties(prefix = "demo")@Getter@Setterpublic class DemoProperties{ private String var1; private String var2; }
package service; import lombok.AllArgsConstructor; @AllArgsConstructorpublic class DemoService { public String var1; public String var2; public String variable(){ return this.var1 + " " + this.var2; } }
@Configuration@EnableConfigurationProperties(DemoProperties.class)// 只有当(😃)name的值与havingValue的值相同的时候加载@ConditionalOnProperty( prefix = "demo", name = "isopen", havingValue = "true")public class DemoConfig { @Resource private DemoProperties demoProperties; @Bean public DemoService demoService(){ return new DemoService(demoProperties.getVar1(),demoProperties.getVar2()); }}
<!--引入我写的starter--><dependency> <groupId>org.oldoldcoder</groupId> <artifactId>oldoldcoder-spring-boot-starter</artifactId> <version>1.0-SNAPSHOT</version></dependency>
# 使用(🏟)自己写的starterdemo.isopen=truedemo.var1=var1demo.var2==var2
@Componentpublic class TestService { @Resource private DemoService demoService; @PostConstruct public void test(){ System.out.println("你好"+demoService.variable()); }}
1.请问哪个网站可以免费在线观看动漫《337p日本大胆人术艺术69》?
优酷视频网友:http://www.ahxhhy.com/cctv/6438897.html
2.《337p日本大胆人术艺术69》是什么时候上映/什么时候开播的?
腾讯视频网友:上映时间为2022年,详细日期可以去百度百科查一查。
3.《337p日本大胆人术艺术69》是哪些演员主演的?
爱奇艺网友:337p日本大胆人术艺术69演员表有,导演是。
4.动漫《337p日本大胆人术艺术69》一共多少集?
电影吧网友:目前已更新到全集已完结
5.手机免费在线点播《337p日本大胆人术艺术69》有哪些网站?
手机电影网网友:美剧网、腾讯视频、电影网
6.《337p日本大胆人术艺术69》评价怎么样?
百度最佳答案:《337p日本大胆人术艺术69》口碑不错,演员阵容强大演技炸裂,并且演员的演技一直在线,全程无尿点。你也可以登录百度问答获得更多评价。
Copyright © 2008-2024