当前位置首页电影《黄色av大片》

《黄色av大片》

类型:战争 枪战 恐怖 印度 2000 

主演:卓在勋 林元熙 李尚敏 金俊浩 宋旻浩 表志勋 

导演:罗暎锡 朴贤勇 

剧情简介

spring项目中starter包的原理,以及自定义starter包的使用 MAVEN项目中starter的原理一.原始方式

我们最早配置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项目的依赖。

<dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-web</artifactId>        </dependency>
二.starter内部(🏛)详情

starter文件也只是一个pom文件,而不是jar,它的目的也是去自动的(☕)引入(🚗)其他的jar文件,上图展示的spring-boot-starter-web中的依赖就有spring-boot-starter。

starter只是一个pom文件

下面也就是starter的关键所(📋)在,请问我(👘)们为什么引入了starter之后只需要配(🎈)置一点点的个性化设置,例如创建application.properties仅仅配置端口等等就可以完成启动应用?是谁帮助我们配置了其他复杂的信(🤐)息?

引出自动配(⏪)置

三.自动配置1.自动配置类的梳理

自动配置主要通过xxxAutoConfiguration这(😀)些类来实现,我们查找一个这样的类来进行示例演示

上图是DataSourceAutoConfiguration这个自动配置类,我们可以看到类上的几(🚃)个注解。

@Configuration 将该类标记为配置类,@Configuration注解的类(🌨)可以看作是能生产让Spring IoC容器管理的Bean实例的工厂@ConditionalOnClass表示某个类位于类路径上时候,才会实例化这个bean@EnableConfigurationProperties注解(🐁)的作用是使@ConfigurationProperties注解生效。如果(🔮)只配置@ConfigurationProperties注解,在(🐒)spring容器中是获取不到(💽)yml或者properties配置文件转化的bean的。

我们点击@EnableConfiguration注解中的@DataSourceProperties进(💡)去查看

可以查看到这里使用@configurationPropertes,@ConfigurationProperties注解的作用是把yml或者properties配置(🔉)文件转化为bean。

同时这里也设置了prefix前缀,在我们项目的application.properties中配置的时候,提示的就是这些bean实例中的属性。

所以是使用@ConfigurationProperties和@EnableConfigurationProperties这两个注解来完成将一个包含众多属性的类来注册成为可供springIoc容器管理的bean。

而这个bean的注册过程是在各个XXXAutoConfiguration类中完成(💞)的。

2.如何发现(📵)依赖包中的bean

我们都知(📂)道springboot默认扫描启动类下面的主类和子类的bean来完成注解,但是并没有包括依赖包中的类,那么依赖包中的bean是如何被发现和加载的?

关键在于@SpringBootApplication这(🕖)个注解

注解层次:

@springbootApplication@SpringBootConfiguration:和@Configuration相同的用处,并且(🎙)将里面通过@bean注(🚰)解标注的方法的返(🥃)回值作为bean对象注册到ioc容器之中(🏖)。获得bean的两种方式,一种是在配置类中通过方法返回,一种是直接在类上注解@bean(或者相同的注解,类似@Mapper等)来注册为bean实例@EnableAutoConfiguration:借助@Import的支持,收(📏)集和注册依赖包中相关的(⤴)bean定义。@Import({AutoConfigurationImportSelector.class}):该注解(🌍)扫描依赖包下需要注册为bean的自动配置类。复制代码protected List<String> getCandidateConfigurations(AnnotationMetadata metadata, AnnotationAttributes attributes) { List<String> configurations = SpringFactoriesLoader.loadFactoryNames(this.getSpringFactoriesLoaderFactoryClass(), this.getBeanClassLoader()); Assert.notEmpty(configurations, "No auto configuration classes found in META-INF/spring.factories. If you are using a custom packaging, make sure that file is correct."); return configurations; }SpringFactoriesLoader.loadFactoryNames方法调用(👇)loadSpringFactories方法从所有的jar包中读取META-INF/spring.factories文件(🏽)信息。而(📔)Spring.factories中key/value中就有一个key是:org.springframework.boot.autoconfigure.EnableAutoConfiguration,后面跟(🗳)着的都是需要AutoConfigurationImportSelector来进行注册的自动配置类# Auto Configure org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ org.mybatis.spring.boot.autoconfigure.MybatisLanguageDriverAutoConfiguration,\ org.mybatis.spring.boot.autoconfigure.MybatisAutoConfiguration@AutoConfigurationPackage@Import({Registrar.class}):Registrar就是扫描启动类目录下的所有bean并且注册,具体实现通过下列代码:static class Registrar implements ImportBeanDefinitionRegistrar, DeterminableImports { Registrar() { } public void registerBeanDefinitions(AnnotationMetadata metadata, BeanDefinitionRegistry registry) { AutoConfigurationPackages.register(registry, (new AutoConfigurationPackages.PackageImport(metadata)).getPackageName()); } public Set<Object> determineImports(AnnotationMetadata metadata) { return Collections.singleton(new AutoConfigurationPackages.PackageImport(metadata)); } }

注解层次图示:

3.如何加载(🔉)发现(👋)的bean

如果要让一个普通类交给Spring容器管理,通常有以下方法:

使用 @Configuration与@Bean 注解使用(👡)@Controller @Service @Repository @Component 注解标(🍪)注该类,然后启用@ComponentScan自动扫描使用@Import 方法

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的流程:

我们确定好自定义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使用自己域名的反写(💶)即可。

项目结构如下:

1.pom文件导入依赖
 <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>

依赖:(🏋)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包中

2.编写(🌠)代码

编写自动配置类代码:(🏫)

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; }

编写service代码:

package service;  import lombok.AllArgsConstructor; @AllArgsConstructorpublic class DemoService {     public String var1;     public String var2;     public String variable(){        return this.var1 + " " + this.var2;    } }

编写config类:

@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());    }}

关于这里@ConditionOnProperty这个注解,该注解的大概含义就是,对于前缀是demo的属性,底下的值isopen为true时候,该自动配置类才(🗂)会生效。

编写spring.factories

将key:EnableAutoConfiguration-->DemoConfig这个类

3.打包

使用maven命令:mvn clean compile install 清理,编译,发布到本地仓库中去

4.其他项目引入(🖐)
<!--引入我写的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());    }}

结果

【黄色av大片的相关新闻】

猜你喜欢

💟相关问题

1.请问哪个网站可以免费在线观看动漫《黄色av大片》?

优酷视频网友:http://www.ahxhhy.com/video/455665009.html

2.《黄色av大片》是什么时候上映/什么时候开播的?

腾讯视频网友:上映时间为2022年,详细日期可以去百度百科查一查。

3.《黄色av大片》是哪些演员主演的?

爱奇艺网友:黄色av大片演员表有,导演是。

4.动漫《黄色av大片》一共多少集?

电影吧网友:目前已更新到全集已完结

5.手机免费在线点播《黄色av大片》有哪些网站?

手机电影网网友:美剧网、腾讯视频、电影网

6.《黄色av大片》评价怎么样?

百度最佳答案:《黄色av大片》口碑不错,演员阵容强大演技炸裂,并且演员的演技一直在线,全程无尿点。你也可以登录百度问答获得更多评价。

  • 黄色av大片百度百科 黄色av大片版原著 黄色av大片什么时候播 黄色av大片在线免费观看 黄色av大片演员表 黄色av大片大结局 黄色av大片说的是什么 黄色av大片图片 在线黄色av大片好看吗 黄色av大片剧情介绍      黄色av大片角色介绍 黄色av大片上映时间 
  • Copyright © 2008-2024