承接上文

import注解的使用:

作用:引用时,容器自动创建出这填写的类型的组件,默认组件的名字就是全类名。

往容器中添加两个组件

@Import({User.class, DBHelper.class})

测试:

System.out.println("=======测试import========");
String[] beanNamesForType = run.getBeanNamesForType(User.class);
System.out.println("==============");
for(String s: beanNamesForType){
System.out.println(s);
}
DBHelper bean1 = run.getBean(DBHelper.class);
System.out.println(bean1);

结果:

com.xbhog.pojo.User

user

ch.qos.logback.core.db.DBHelper@68565bc7

可以看出,使用import的组件返回名字时全类名,我们自己写的组件,就是原来的。

条件装配

条件装配:满足Conditional指定的条件,则进行组件注入.

组件注解:

实例采用以下两个为例:

  1. @ConditionalOnMissingBean(name="tom11")
  2. @ConditionalOnBean(name="tom11")
  1. ConditionalOnMissingBean表示当容器中没有这个tom11组件时,执行下面的组件

    @Import({User.class, DBHelper.class})
    @Configuration(proxyBeanMethods = false)
    public class MyConfig {
    @ConditionalOnMissingBean(name="tom11")
    @Bean
    public User user(){
    User user = new User("xbhog", 18);
    return user;
    }
    //@Bean("tom11")
    public Pet tomcat(){
    return new Pet("tomcat");
    }
    }

    主启动程序中的代码片段:

    ConfigurableApplicationContext run = SpringApplication.run(Myapp.class, args);  //返回IOC容器
    boolean tom11 = run.containsBean("tom11");
    //容器中tom11组件:false
    //容器中user组件:true
    System.out.println("容器中tom11组件:"+tom11);
    boolean user = run.containsBean("user");
    System.out.println("容器中user组件:"+user);

    结果:

    容器中tom11组件:false
    容器中user组件:true
  2. ConditionalOnBean表示当容器中存在该组件时,才执行下面的内容

    @Import({User.class, DBHelper.class})
    @Configuration(proxyBeanMethods = false)
    public class MyConfig {
    @ConditionalOnBean(name="tom11")
    @Bean
    public User user(){
    User user = new User("xbhog", 18);
    return user;
    }
    //@Bean("tom11")
    public Pet tomcat(){
    return new Pet("tomcat");
    }
    }

    主程序启动代码:

    ConfigurableApplicationContext run = SpringApplication.run(Myapp.class, args);  //返回IOC容器
    boolean tom11 = run.containsBean("tom11");
    //容器中tom11组件:false
    //容器中user组件:true
    System.out.println("容器中tom11组件:"+tom11);
    boolean user = run.containsBean("user");
    System.out.println("容器中user组件:"+user);

    结果:

    容器中tom11组件:false
    容器中user组件:false

配置绑定:

解决的问题:

将properties文件中的内容绑定到类的属性中,并把它们封装到JavaBean中,以供随时使用

有两种方法实现:

第一种:

采用component+configurationProperties来绑定properties中的数据

properties数据:(brand:别摸我)

mycar.brand = BMW
mycar.price = 200000

编写Car实体类:

package com.xbhog.popj;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component; @Data
@AllArgsConstructor //有参构造
@NoArgsConstructor //无参构造
@Component //将该类加入到容器中,来获得Spring Boot提供的强大的功能
@ConfigurationProperties(prefix="mycar") //实现读取绑定到properties中的以mycar前缀的数据
public class Car {
private String brand;
private String price;
}

编写Controller:

package com.xbhog.controller;

import com.xbhog.popj.Car;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; @RestController
public class MyController {
@Autowired //自动匹配到容器中的car
Car car; @RequestMapping("/car")
public Car car(){
return car;
}
}

实现效果:

{"brand":"BMM","price":"200000"}

第二种:

EnableConfigurationProperties+ConfigurationProperties

@EnableConfigurationProperties(类.class)

功能:

  1. 开启类配置绑定功能
  2. 把这个类这个组件自动注册到容器中

需要把EnableConfigurationProperties注解加到配置类中,因为配置类本身就是组件。

MyConfig:

@Configuration
@EnableConfigurationProperties(Car.class) //开启Car配置绑定功能n并把Car自动注册到容器中
public class MyConfig { }

@ConfigurationProperties(prefix = “mycar”)

找到配置文件中application.properties中的前置为mycar的内容

实现效果:

{"brand":"BMM","price":"200000"}

原生配置文件引入:

使用@ImportResouce注解将bean.xml中的组件加入到容器中

bean.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd"> <bean id="haha" class="com.xbhog.pojo.User">
<property name="name" value="zhangsan"></property>
<property name="age" value="18"></property>
</bean> <bean id="hehe" class="com.xbhog.pojo.Pet">
<property name="name" value="tomcat"></property>
</bean> </beans>
package com.xbhog.springboot1times;

import ch.qos.logback.core.db.DBHelper;
import com.xbhog.config.MyConfig;
import com.xbhog.pojo.Pet;
import com.xbhog.pojo.User;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.SpringBootConfiguration;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.ImportResource; //@SpringBootApplication
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan("com.xbhog")
@ImportResource("classpath:bean.xml")
public class Myapp {
public static void main(String[] args) {
/*1. 返回我们IOC容器*/
ConfigurableApplicationContext run = SpringApplication.run(Myapp.class, args);
boolean haha = run.containsBean("haha");
boolean hehe = run.containsBean("hehe");
System.out.println("是否存在:"+haha+"==="+hehe);
}
}

结果:是否存在:true===true

参考:

尚硅谷B站视频

结束:

如果你看到这里或者正好对你有所帮助,希望能点个关注或者推荐,感谢;

有错误的地方,欢迎在评论指出,作者看到会进行修改。

SpringBoot之了解自动配置原理的更多相关文章

  1. springboot核心技术(二)-----自动配置原理、日志

    自动配置原理 配置文件能配置的属性参照 1.自动配置原理: 1).SpringBoot启动的时候加载主配置类,开启了自动配置功能 @EnableAutoConfiguration 2).@Enable ...

  2. 【springboot】之自动配置原理

    使用springboot开发web应用是很方便,只需要引入相对应的GAV就可以使用对应的功能,springboot默认会帮我们配置好一些常用配置.那么springboot是怎么做到的呢?这篇文章将一步 ...

  3. SpringBoot 2.X集成 jdbc自动配置原理探究

    前言 Springboot对于数据访问层,不管是 SQL还是 NOSQL,Spring Boot 底层都是采用 Spring Data 的方式统一处理.Spring Data 是 Spring 家族中 ...

  4. SpringBoot自动配置原理

    前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 回顾前面Spring的文章(以学习的顺序排好): S ...

  5. SpringBoot的自动配置原理过程解析

    SpringBoot的最大好处就是实现了大部分的自动配置,使得开发者可以更多的关注于业务开发,避免繁琐的业务开发,但是SpringBoot如此好用的 自动注解过程着实让人忍不住的去了解一番,因为本文的 ...

  6. 3. SpringBoot ——自动配置原理浅析

    SpringBoot的功能之所以强大,离不开它的自动配置这一大特色.但估计很多人只是知其然而不知其所以然.下面本人对自动配置原理做一个分析: 在使用SpringBoot时我们通过引入不同的Starte ...

  7. 3springboot:springboot配置文件(外部配置加载顺序、自动配置原理,@Conditional)

    1.外部配置加载顺序 SpringBoot也可以从以下位置加载配置: 优先级从高到低 高优先级的配置覆盖低优先级的配置,所有的配置会形成互补配置  1.命令行参数 所有的配置都可以在命令行上进行指定 ...

  8. SpringBoot之自动配置原理

    我在前面的Helloworld的程序中已经分析过一次,配置原理了: 1).SpringBoot启动的时候加载主配置类,开启了自动配置功能 @EnableAutoConfiguration 2).@En ...

  9. springboot(八) 嵌入式Servlet容器自动配置原理和容器启动原理

    1.嵌入式Servlet容器自动配置原理 1.1 在spring-boot-autoconfigure-1.5.9.RELEASE.jar => springboot自动配置依赖 jar包下,E ...

随机推荐

  1. CentOS:操作系统级监控及常用计数器解析

    我相信有一些人看到这篇文章的标题肯定有种不想看的感觉,因为这样的内容实在被写得太多太多了.操作系统分析嘛,无非就是 CPU 使用率.I/O 使用率.内存使用率.网络使用率等各种使用率的描述. 然而因为 ...

  2. Padavan安装使用ZeroTier实现组建虚拟局域网的方法

    首先到这个网站ZeroTier – Global Area Networking注册登陆,注册及创建网络的过程可以参考网上及其他UP主的教程,我就不重复了. 本篇主要讲述的是hiboy大佬编译的固件在 ...

  3. SpringMVC 进阶版

    请求限制 一些情况下我们可能需要对请求进行限制,比如仅允许POST,GET等... RequestMapping注解中提供了多个参数用于添加请求的限制条件 value 请求地址 path 请求地址 m ...

  4. .NET 云原生架构师训练营(Identity Server)--学习笔记

    目录 OAuth 2.0 OpenID Connect QuickStart OAuth 2.0 概念 过程 通信 组件 示例代码 概念 OAuth 2.0 是一个授权协议,它允许软件应用代表(而不是 ...

  5. 安聊服务端Netty的应用

    Netty简介 Netty是一个面向网络编程的Java基础框架,它基于异步的事件驱动,并且内置多种网络协议的支持,可以快速地开发可维护的高性能的面向协议的服务器和客户端. 安聊简介 安聊是一个即时聊天 ...

  6. kube-controller-manager源码分析-AD controller分析

    kubernetes ceph-csi分析目录导航 概述 kube-controller-manager组件中,有两个controller与存储相关,分别是PV controller与AD contr ...

  7. [源码解析] 深度学习分布式训练框架 horovod (10) --- run on spark

    [源码解析] 深度学习分布式训练框架 horovod (10) --- run on spark 目录 [源码解析] 深度学习分布式训练框架 horovod (10) --- run on spark ...

  8. Linux-ELK日志收集

    1.ELK简介 ELK是三个开源软件的缩写,分别表示:Elasticsearch , Logstash, Kibana , 它们都是开源软件.新增了一个FileBeat,它是一个轻量级的日志收集处理工 ...

  9. Ansible自动化运维应用实战

    实验环境 centos7.4 主机名称 IP 配置 用途 controlnode 172.16.1.120 1核/1G/60G ansible slavenode1 172.16.1.121 1核/1 ...

  10. 21、linux系统grup和bios加密

    21.1.grup加密(加密单用户模式): 1.使用加密算法对grup密码进行加密: 2.修改grup.conf配置文件: 21.2.bios加密(因为救援模式可以破解grup加密,所以使用bios加 ...