基于注解的spring开发之组件注册

2019-02-11  本文已影响0人  Burning_6c93
  1. @Configuration注解 这个相当于配置文件,即告诉spring这个一个配置类。
  2. @Bean
    给容器注册一个Bean;类型为返回值的类型,id默认是用方法名作为id.
@Configuration
public class MainConfig {
    @Bean
    public Person per(){
        return new Person("李四",22 );
    }
}

这个基本就相当于以前采用的xml配置文件如下:

<bean id="per" class="com.learn.entity.Person">
     <property name="name" value="李四" />
     <property name="age" value="22"/>
</bean>

  1. @ComponentScan
    自动包扫描注解
    value:指定要扫描的包
    excludeFilters=Filter[] 指定扫描的时候按照什么规则排除哪些组件。
    includeFilters=Filter[] 指定扫描的时候只需要包含哪些组件。(注意的是包扫描默认的是扫描所有的,也就是use-default-filters=”true”,所以需要设置为false。 这个和配置文件一样)
    • FilterType.ANNOTATION :按照注解的方式
    • FilterType.ASSIGNABLE_TYPE:按照给定的类型
    • FilterType.CUSTOM:使用自定义规则。 使用这个需要是TypeFilter的实现类
      FilterType.CUSTOM使用 案例如下:
public class MyFilterCustom implements TypeFilter {
    /**
     * metadataReader 读取到的当前正在扫描的类的信息
     * metadataReaderFactory 可以获取到其它任何类的信息
     */
    public boolean match(MetadataReader metadataReader, MetadataReaderFactory metadataReaderFactory)
            throws IOException {
        //获取当前类注解的信息
        AnnotationMetadata annotationMetadata = metadataReader.getAnnotationMetadata();
        //获取当前正在扫描的类的信息
        ClassMetadata classMetadata = metadataReader.getClassMetadata();
        //获取当前类资源(类路径)
        Resource resource = metadataReader.getResource();
        String className = classMetadata.getClassName();
        System.out.println("当前扫描的类的信息"+className);
        if(className.contains("Controller")){
            return true;
        }
        return false;
    }
}
@Configuration
@ComponentScans(value={
        @ComponentScan(value="com.learn",
                includeFilters={
                        @Filter(type=FilterType.CUSTOM,classes={MyFilterCustom.class})
                        },useDefaultFilters=false)
})
public class MainConfig {
    @Bean
    public Person per(){
        return new Person("李四",22 );
    }
}
@Configuration
@ComponentScan(value="com.learn",
includeFilters={
       @Filter(type=FilterType.ANNOTATION,
               classes={Controller.class}
               )},useDefaultFilters=false)
public class MainConfig {
   @Bean
   public Person per(){
       return new Person("李四",22 );
   }
}

  1. @ComponentScans 这个就是多个scan的几个集合,也就是可以定义多个规则。 如果是jdk1.8以后的,本身也是可以多些几次scan。 不用scans也可以
@Configuration
@ComponentScans(value={
        @ComponentScan(value="com.learn",
                includeFilters={
                        @Filter(type=FilterType.ANNOTATION,
                                classes={Controller.class}
                                )},useDefaultFilters=false)
})
public class MainConfig {
    @Bean
    public Person per(){
        return new Person("李四",22 );
    }
}

  1. @Scope 作用范围
    • prototype 多实例的 备注:IOC容器启动并不会去调用方法创建对象放在容器中,而是在每次获取的时候才会调用方法创建对象,且每次创建的都是一个新的,即多实例。
    • singleton 单实例的(默认值) 备注:默认在单实例的情况下,IOC容器启动的时候会调用方法创建对象,放入iOC容器中。 以后每次获取就是从容器中拿,即对象都是一个。
    • request 同一次请求创建一个实例(web环境中才能用到,且基本不用)
    • session 同一个session创建一个实例(web环境中才能用到,且基本不用)
@Configuration
public class MainConfig2 {
    @Bean
    public Person person(){
        return new Person("张三", 28);
    }
}
@Configuration
public class MainConfig2 {
    @Bean
    @Scope("prototype")  //多例
    public Person person(){
        return new Person("张三", 28);
    }
}
  1. @Lazy 懒加载,针对单实例的bean
    懒加载:容器启动不创建对象。第一次使用(获取bean)创建的对象,并初始化。
@Configuration
public class MainConfig2 {
    @Bean
    @Lazy
    public Person person(){
        System.out.println("调用了person方法");
        return new Person("张三", 28);
    }
}
  1. @Conditional 按照一定的条件进行判断,满足条件给容器中注册bean。
@Configuration
public class MainConfig2 {

    @Bean("win")
    @Conditional(WindowConditional.class)
    public Person person1(){
        return new Person("Windows", 70);
    }
    @Bean("Lin")
    @Conditional(LinuxConditional.class)
    public Person person2(){
        return new Person("Linux", 80);
    }
}
上一篇下一篇

猜你喜欢

热点阅读