1、根据条件来装配bean,SpringBoot的自动配置,根据条件进行自动配置。

首先创建一个接口,如下所示:

package com.bie.encoding;

/**
*
* @Description TODO
* @author biehl
* @Date 2018年12月31日 上午10:57:07
*
*/ public interface EncodingConvert { }

然后创建两个实现类,这个只是举例说明了其功能,举得字符编码的栗子:

package com.bie.encoding;

/**
*
* @Description TODO
* @author biehl
* @Date 2018年12月31日 上午10:56:46
*
*/ public class GBKEncodingConvert implements EncodingConvert{ }
package com.bie.encoding;

/**
*
* @Description TODO
* @author biehl
* @Date 2018年12月31日 上午10:56:58
*
*/ public class UTF8EncodingConvert implements EncodingConvert{ }

将GBK和UTF8的类进行装配:

实现了Condition接口的类也添加了,自己可以进行对比操作。

基于条件的自动装配,一般配合Condition接口一起使用,只有接口的实现类返回true,才装配,否则不装配。它可以用在方法上面,则直怼方法起作用,还可以用在类上面,则对该类下面的所有方法起作用。

@Conditional的参数值是一个数组,所以可以传递多个值进去,这样只有当所有都返回true的时候才会执行。否则不执行。

 package com.bie.encoding;

 import org.springframework.boot.SpringBootConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Conditional; /**
*
* @Description TODO
* @author biehl
* @Date 2018年12月31日 上午11:05:22
*
*/
@SpringBootConfiguration //@SpringBootConfiguration和@Configuration作用和效果一样的
public class EncodingConvertConfiguration { /**
* 装配
* @return
*/
@Bean
@Conditional(UTF8Condition.class)
public EncodingConvert createUTF8EncodingConvert() {
return new UTF8EncodingConvert();
} /**
* 装配
* @return
*/
@Bean
@Conditional(GBKCondition.class)
public EncodingConvert createGBKEncodingConvert() {
return new GBKEncodingConvert();
} }

然后可以写一个主类,不自动装配看看效果如何,然后装配了效果如何:

 package com.bie;

 import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext; import com.bie.encoding.EncodingConvert; /**
*
* @Description TODO
* @author biehl
* @Date 2018年12月31日 上午11:08:47
*
*/
@SpringBootApplication
public class EncodingConvertApplication { public static void main(String[] args) {
ConfigurableApplicationContext context = SpringApplication.run(EncodingConvertApplication.class, args);
//未装配的现象,将gbk和utf8都打印输出
//装配的现象是,只输出了utf8的
String encoding = System.getProperty("file.encoding");
System.out.println("encoding : " + encoding);
System.out.println(context.getBeansOfType(EncodingConvert.class)); //关闭
context.close();
} }

下面将实现Condition接口的实现类,来实现SpringBoot的自动装配:

package com.bie.encoding;

import org.springframework.context.annotation.Condition;
import org.springframework.context.annotation.ConditionContext;
import org.springframework.core.type.AnnotatedTypeMetadata; /**
*
* @Description TODO
* @author biehl
* @Date 2018年12月31日 上午11:16:09
* 1、true表示装配,false表示不装配。
*/ public class UTF8Condition implements Condition{ @Override
public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {
String encoding = System.getProperty("file.encoding");
if(encoding != null) {
return "utf-8".equals(encoding.toLowerCase());
}
//true表示装配,false表示不装配。
return false;
} }
package com.bie.encoding;

import org.springframework.context.annotation.Condition;
import org.springframework.context.annotation.ConditionContext;
import org.springframework.core.type.AnnotatedTypeMetadata; /**
*
* @Description TODO
* @author biehl
* @Date 2018年12月31日 上午11:13:13
* 1、true表示装配,false表示不装配。
*/ public class GBKCondition implements Condition{ /**
*
*/
public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {
String encoding = System.getProperty("file.encoding");
if(encoding != null) {
return "gbk".equals(encoding.toLowerCase());
}
//true表示装配,false表示不装配。
return false;
} }

运行效果如下所示:

SpringBoot的自动装配的类可以查看源码,位置如下所示:

待续......

SpringBoot的自动配置的更多相关文章

  1. springboot(六)自动配置原理和@Conditional

    官方参考的配置属性:https://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/htmlsingle/#common-appl ...

  2. springboot mvc自动配置(一)自动配置DispatcherServlet和DispatcherServletRegistry

    所有文章 https://www.cnblogs.com/lay2017/p/11775787.html 正文 springboot的自动配置基于SPI机制,实现自动配置的核心要点就是添加一个自动配置 ...

  3. springboot mvc自动配置(三)初始化mvc的组件

    所有文章 https://www.cnblogs.com/lay2017/p/11775787.html 正文 在springboot mvc自动配置的时候,获得了DispatcherServlet和 ...

  4. 关于SpringBoot的自动配置和启动过程

    一.简介 Spring Boot简化了Spring应用的开发,采用约定大于配置的思想,去繁从简,很方便就能构建一个独立的.产品级别的应用. 1.传统J2EE开发的缺点 开发笨重.配置繁多复杂.开发效率 ...

  5. 面试题: SpringBoot 的自动配置原理

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 3.Spring Boot 的自动配置原理 package com.mmall; import org. ...

  6. spring-boot spring-MVC自动配置

    Spring MVC auto-configuration Spring Boot 自动配置好了SpringMVC 以下是SpringBoot对SpringMVC的默认配置:==(WebMvcAuto ...

  7. Springboot MVC 自动配置

    Springboot MVC 自动配置 官方文档阅读 https://docs.spring.io/spring-boot/docs/current/reference/html/web.html#w ...

  8. SpringBoot的自动配置原理

    一.入口 上篇注解@SpringBootApplication简单分析,说到了@SpringBootApplication注解的内部结构, 其中@EnableAutoConfiguration利用En ...

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

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

随机推荐

  1. ios端position为fixed失效的解决办法

    关键代码 document.getElementById("searchInputbox").addEventListener('touchmove', handler, {pas ...

  2. mysql 数据库表迁移复制

    1. 表结构相同的表,且在同一数据库(如,table1,table2) insert into table1 select * from table2 # 完全复制 insert into table ...

  3. SQL学习指南第四篇

    SQL必知必会(第4版)学习笔记 插入数据 插入有几种方式: 插入完整的行 插入行的一部分 插入某些查询的结果(INSERT SELECT) 注意:省略列 如果表的定义允许,则可以在 INSERT 操 ...

  4. Kettle中并行执行测试

    整个作业截图: 设置并行方法:右键 START 组件,勾选最后一个选项: Run Next Entries In Parallel 设置aa, bb, cc, dd, ee 都是shell脚本,内容都 ...

  5. 轻量Pythonweb - flask+jinja2

    后台代码 MVC from flask import Flask,request,render_template app = Flask(__name__) @app.route('/',method ...

  6. 2、搭建一个简单的Web项目

    一.创建一个Web项目: 1.File->new Project->Java->JavaEE->Web Application 2.为项目起名: 3.配置项目:在项目上击右键- ...

  7. JMX/RMI Nice ENGAGE <= 6.5 Remote Command Execution

    CVE ID : CVE-2019-7727 JMX/RMI Nice ENGAGE <= 6.5 Remote Command Execution description=========== ...

  8. 一个疑问,int对象5为何没有__dict__属性,而类却有,这是怎么做到的?对象不是都可以调用类属性吗?

    a=1 print hasattr(a.__dict__) print hasattr(a.__class__.__dict__)

  9. 根据ul的class和li的class获取li的value值

    <ul class="bd exam" style="display: none;"> <li class="cwhite acti ...

  10. sqli注入--利用information_schema配合双查询报错注入

    目录 sqli-labs 5.6双查询报错注入通关 0x01 获取目标库名 0x02 获取库中表的数量 0x03 获取库中表名 0x04 获取目标表中的列数 0x05 获取目标表的列名 0x06 从列 ...