zoukankan      html  css  js  c++  java
  • Spring @Conditional注解的使用

    http://blog.csdn.net/mn960mn/article/details/51190590

    spring Boot的强大之处在于使用了Spring 4框架的新特性:@Conditional注释,此注释使得只有在特定条件满足时才启用一些配置。

    下面来介绍如何使用Condition

    首先写一个类

    [java] view plain copy
    1. package com.test.spring;  
    2.   
    3. import org.springframework.context.annotation.Condition;  
    4. import org.springframework.context.annotation.ConditionContext;  
    5. import org.springframework.core.type.AnnotatedTypeMetadata;  
    6.   
    7. public class MyCondition implements Condition  
    8. {  
    9.     /** 
    10.      * 这里写自己的逻辑,只有返回true,才会启用配置 
    11.      */  
    12.     public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata)  
    13.     {  
    14.         return true;  
    15.     }  
    16. }  


    接下来就可以使用了

    [java] view plain copy
    1. package com.test.spring;  
    2.   
    3. import java.io.Serializable;  
    4.   
    5. import org.springframework.context.annotation.Bean;  
    6. import org.springframework.context.annotation.Conditional;  
    7. import org.springframework.context.annotation.Configuration;  
    8.   
    9. @Configuration  
    10. @Conditional(MyCondition.class)  
    11. public class Config  
    12. {  
    13.     @Bean  
    14.     public Serializable createSerializable()  
    15.     {  
    16.         System.out.println("======000");  
    17.         return "";  
    18.     }  
    19. }  


    @Conditional(MyCondition.class)

    这句代码可以标注在类上面,表示该类下面的所有@Bean都会启用配置

    也可以标注在方法上面,只是对该方法启用配置

    除了自己自定义Condition之外,Spring还提供了很多Condition给我们用

    @ConditionalOnBean(仅仅在当前上下文中存在某个对象时,才会实例化一个Bean)
    @ConditionalOnClass(某个class位于类路径上,才会实例化一个Bean)
    @ConditionalOnExpression(当表达式为true的时候,才会实例化一个Bean)
    @ConditionalOnMissingBean(仅仅在当前上下文中不存在某个对象时,才会实例化一个Bean)
    @ConditionalOnMissingClass(某个class类路径上不存在的时候,才会实例化一个Bean)
    @ConditionalOnNotWebApplication(不是web应用)

  • 相关阅读:
    Ztree下拉框多选
    FullCalendar日程插件
    viscose 前端常用插件
    一些词
    关于require()和export引入依赖的区别
    关于CMD/AMD和Common.js/Sea.js/Require.js
    vue中的双向数据绑定原理简单理解
    Vue-cli简单使用
    webpack简单配置
    vuex基础
  • 原文地址:https://www.cnblogs.com/xingzc/p/7490870.html
Copyright © 2011-2022 走看看