Spring通过注解来配置Bean

1.组件描述

  • 组件扫描(component scanning):Spring能够从classpath下自动扫描,侦测和实例化具有特点注解的组件
  • 特点组件包括:
    • @Component    一般用于自定义组件,把普通类实例化到spring容器中,相当于配置文件中的
    • @Repository   一般用于数据访问(数据访问(持久)层组件,实现dao访问)
    • @Service    一般用于服务(业务层组件,处理业务逻辑,比如注入并操作dao)
    • @Controller    一般用于控制器(控制层组件)
      【本质上所有的特定组件可以混用,因为在IOC里面没有绝对性的对这几个组件进行名称上的区分,但是建议按照标准进行使用】

对于扫描到的组件,spring有默认的命名策略:使用非限定类名,第一个字母小写,也可以在注解中通过value属性值标识组件的名称

2.文件配置

  • 当在组件类上使用了特定的注解之后,还需要再Spring的配置文件中声明

    • base-package属性指定一个需要扫描的基类包,Spring容器将会扫描这个基类包里以及子包中所有的类。
    • 当需要扫描多个包时,可以使用逗号分隔。
    • 如果仅希望扫描特定的类而非基包下的所有类,可使用resource-pattern属性过滤特定的类,示例:
    
    <context:component-scan base-package="com.yidu.annotation" resource-pattern="annotation/*.class">
     <context:include-filter>子节点表示要包含的目标类
     <context:exclude-filter>子节点表示要排除在外的目标类
    context:component-scan>
    • 下可以拥有若干个子节点
      context:include-filter和context:exclude-filter子节点支持多种类型的过滤表达式:
类别 示例 说明
annotation com.yl.XxxAnnotation 所有标注了XxxAnnotation的类,该类型采用目标类是否标注了某个注解进行过滤
assinable com.yl.XxxService 所有继承或扩展XxxService的类,该类型采用了目标类是否继承或扩展某个特定类进行过滤
aspectj com.yl.*Service 所有类名义Service结束的类及继承或扩展它们的类,该类型采用AspectJ表达式进行过滤
regex com.yl.anno.* 所有com.yl.anno包下的类。该类型采用正则表达式,根据类的类名进行过滤
custom com.yl.XxxTypeFilter 采用XxxTypeFilter通过代码的方式定义过滤原则。该类必须实现org.springframework.core.type.TypeFilter接口

示例:



 <context:component-scan base-package="com.yidu.annotation">
  <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Repository" /> 
 context:component-scan>


 <context:component-scan base-package="com.yidu.annotation" use-default-filters="false">
  <context:include-filter type="annotation" expression="org.springframework.stereotype.Repository"/>
 context:component-scan>

context:include-filter需要在context:component-scan中配置use-default-filters="false"才能生效

3.组件装配

元素还会自动注册AutowiredAnnotationBeanPostProcessor实例,该实例可以自动装配具有@Autowired和@Resource、@Inject注解的属性
使用@Autowired自动装配bean

  • @Autowired注解自动装配具有兼容类型的单个bean属性

    • 构造器,普通字段(即使是非public),一切只有参数的方法都可以应用@Autowired
    • 默认情况下,所有使用@Autowired注解的属性都需要被设置,当Spring找不到匹配的bean装配属性时,会抛出异常。若某一属性允许不被设置,可以设置@Autowired注解的required属性为false
    • 默认情况下,当IOC容器里存在多个类型兼容的bean时,通过类型的自动装配将无法工作。此时可以在@Qualifiter注解里提供bean的名称,Spring允许对方法的入参标注 @Qualifiter已指定注入bean的名称
    • @Autowired注解也可以应用在数组类型的属性上,此时Spring将会把所有匹配的bean进行自动匹配
    • @Autowired注解也可以应用在集合属性上,此时Spring读取该集合的类型信息,然后自动装配所有与之兼容的bean
    • @Autowired注解用在java.util.Map上时,若该Map的键值作为String,那么Spring将自动装配与之Map值类型兼容的bean,此时bean的名称作为键值
  • 使用@Resource或@Inject自动装配bean

Spring还支持@Resource和@Inject注解,这两个注解和@Autowired注解的功用类似

@Resource注解要求提供一个bean名称的属性,若该属性为空,则自动采用标注处的变量或方法名作为bean的名称

@Inject和@Autowired注解一样也是按类型注入的bean,但是没有required属性
建议使用@Autowired注解

你可能感兴趣的:(温故知新,#,Spring)