Spring框架的核心功能有两个:
Spring容器作为超级大工厂,负责创建、管理所有的Java对象,这些Java对象被称为Bean。Spring容器管理容器中Bean之间的依赖关系,Spring使用一种被称为"依赖注入"的方式来管理Bean之间的依赖关系。设值注入 设值注入是指IoC容器通过成员变量的setter方法来注入被依赖对象。这种注入方式简单、直观,因而在Spring的依赖注入里大量使用。 构造注入 利用构造器来设置依赖关系的方式,被称为构造注入。通俗来说,就是驱动Spring在底层以反射方式执行带指定参数的构造器,当执行带参数的构造器时,就可利用构造器参数对成员变量执行初始化——这就是构造注入的本质。
对应的Java文件为
public class Person { private String name; private int age; 还有get/set方法 }Bean内也可以注入其他对象,配置时使用ref
<bean id="idd" class="com.cc.Person"> <property name="name" value="jia"></property> <property name="age" value="12"></property> <property name="dog" ref="gouer"></property> </bean> <bean id="gouer" class="com.cc.Dog"> <property name="name" value="xiaogou"></property> </bean>成员为集合时使用list属性
<property name="dog" > <list > <ref bean="dog1"/> <ref bean="dog2"/> </list> </property>成员为Map时使用map属性
<property name="dog" > <map > <entry key="AA" value-ref="dog1"/> <entry key="BB" value-ref="dog2"/> </map> </property>配置properties属性
<property name="properties" > <props > <prop key="user" >root</prop> <prop key="password" >123123</prop> </props> </property>Spring能自动装配Bean与Bean之间的依赖关系,即无须使用ref显式指定依赖Bean,而是由Spring容器检查XML配置文件内容,根据某种规则,为调用者Bean注入被依赖的Bean。
//byNmae和byType两种 <bean id="idd" class="com.cc.Person" p:name="" autowire="byName"> </bean>子Bean继承父Bean,包括属性配置,可以覆盖配置 若父Bean只是作为模板使用,可设<bean≥的abstract属性为true; 父Bean的class属性可以忽略;
对于开发者来说,开发者使用Spring框架主要是做两件事:①开发Bean;②配置Bean。对于Spring框架来说,它要做的就是根据配置文件来创建Bean实例,并调用Bean实例的方法完成"依赖注入"——这就是所谓IoC的本质。 容器中Bean的作用域 当通过Spring容器创建一个Bean实例时,不仅可以完成Bean实例的实例化,还可以为Bean指定特定的作用域。Spring支持如下五种作用域: bean中属性 scope=" "
singleton: 单例模式,在整个Spring IoC容器中,singleton作用域的Bean将只生成一个实例。prototype: 每次通过容器的getBean()方法获取prototype作用域的Bean时,都将产生一个新的Bean实例。request: 对于一次HTTP请求,request作用域的Bean将只生成一个实例,这意味着,在同一次HTTP请求内,程序每次请求该Bean,得到的总是同一个实例。只有在Web应用中使用Spring时,该作用域才真正有效。session:该作用域将 bean 的定义限制为 HTTP 会话。 只在web-aware Spring ApplicationContext的上下文中有效。global session: 每个全局的HTTP Session对应一个Bean实例。在典型的情况下,仅在使用portlet context的时候有效,同样只在Web应用中有效。如果不指定Bean的作用域,Spring默认使用singleton作用域。prototype作用域的Bean的创建、销毁代价比较大。而singleton作用域的Bean实例一旦创建成果,就可以重复使用。因此,应该尽量避免将Bean设置成prototype作用域。
SpEL是一个支持运行时查询和操作对象图的强大的表达式语言。 SpEL使用#{…}座位定界符,在大括号中的字符是SpEL。 SpEL里可以使用Java语句
Spring IOC 容器对 Bean 的生命周期进行管理的过程:
通过构造器或工厂方法创建 Bean 实例为 Bean 的属性设置值和对其他 Bean 的引用调用 Bean 的初始化方法Bean 可以使用了当容器关闭时, 调用 Bean 的销毁方法在 Bean 的声明里设置 init-method 和 destroy-method 属性, 为 Bean 指定初始化和销毁方法.
Spring提供如下几个Annotation来标注Spring Bean:
@Component: 标注一个普通的Spring Bean类@Controller: 标注一个控制器组件类@Service: 标注一个业务逻辑组件类@Repository: 标注一个DAO组件类配置文件 指定容器扫描的包
<context:component-scan base-package="要扫描的基类包和子包"/>其他扫描模式 如果仅希望扫描特定的类而非基包下的所有类,可使用 resource-pattern 属性过滤特定的类,示例:
<context:component-scan base-package="要扫描的包" resource-pattern="autowire/*.class"/>筛选器选择
<context:include-filter> 子节点表示要包含的目标类,在主标签设置use-default-filters="false",就只使用该筛选器扫描<context:exclude-filter> 子节点表示要排除在外的目标类<context:component-scan> 下可以拥有若干个 <context:include-filter> 和 <context:exclude-filter> 子节点
<context:component-scan base-package="要扫描的基类包和子包"> <context:exclude-filter type="annotation" expression="筛选包"/> </context:component-scan>默认情况下, 当 IOC 容器里存在多个类型兼容的 Bean 时, 通过类型的自动装配将无法工作. 此时可以在 @Qualifier 注解里提供 Bean 的名称. Spring 允许对方法的入参标注 @Qualifiter 已指定注入 Bean 的名称