Bean是Spring中非常重要的部分,
<Bean>
factory-bean : 属性来指定实例化Bean的Bean
factory-method : 属性来指定实例化Bean的方法.
例如
<!--定义实例工厂Bean -->
<bean id="beanInstanceFactory" class="cn.javass.spring.chapter2.HelloApiInstanceFactory"/>
<!--使用实例工厂Bean创建Bean -->
<bean id="bean4" factory-bean="beanInstanceFactory"
factory-method="newInstance">
<constructor-arg index="0" value="Hello Spring!"></constructor-arg> </bean>
newInstance是bean4中的静态方法,返回bean4实例,如果newInstance不是bean4的方法,使用factory-bean=”Bean_name“来指定Bean
例如
<bean id="instanceFactory"
class="cn.javass.spring.chapter3.DependencyInjectByInstanceFactory"/>
<bean>
id="byIndex"factory-bean="instanceFactory"
factory-method="newInstance">
<constructor-arg index="0" value="Hello World!"/>
<constructor-arg index="1" value="1"/>
</bean>
<bean id="byType" factory-bean="instanceFactory"
factory-method="newInstance">
<constructor-arg type="java.lang.String" value="Hello World"/>
</bean>
lazy-init = “true” or “false”
延时初始化
延迟初始化的Bean通常会在第一次使用时被初始化;或者在被非延迟初始化Bean作为依赖对象注入时在会随着初
始化该Bean时被初始化,因为在这时使用了延迟初始化Bean
alias Bean的别名。
init-method=“init”
destroy-method=“destroy”
指定初始化及销毁方法。
depends-on =”Bean_name“
使用depends-on
depends-on是指指定Bean初始化及销毁时的顺序,使用depends-on属性指定的Bean要先初始化完毕后才初始
化当前Bean,由于只有“singleton”Bean能被Spring管理销毁,所以当指定的Bean都是“singleton”时,使用
depends-on属性指定的Bean要在指定的Bean之后销毁
“depends-on”属性可以指定多个Bean,若指定多个Bean可以用“;”、“,”、空格分割
autowire :自动装配 “no”、“byName ”、“byType”、“constructor”
项目 | Value |
---|---|
no | 不支持自动装配,请手动 |
byName | 意思是根据名字进行自动装配,只能用于setter注入 |
byType | 根据类型注入,用于setter注入, |
constructor | 功能和“byType”功能一样,根据类型注入构造器参数,只是用于构造器注入方式 |
byType 如果找到多个Bean将优先注入
<bean>标签“primary”属性为true的Bean,否则抛出异常来表明有个多个Bean发现但不知道使用哪个。
autowire-candidate=“false”
通过设置Bean定义的“autowire-candidate”属性为false来把指定Bean后自动装配候选者中移除:
<bean name="bean" class="cn.javass.spring.chapter2.helloworld.HelloImpl"/>
<alias alias="alias1" name="bean"/>
设置别名的另一种方法。
多个name用“,”、“;”、“ ”分割,第一个被用作标识符,其他的(alias1、alias2、alias3)是别名。
<bean name=”bean1;alias11,alias12;alias13 alias14”
class=” cn.javass.spring.chapter2.helloworld.HelloImpl”/>
<!-- 当指定id时,name指定的标识符全部为别名 -->
<bean id="bean2" name="alias21;alias22" class="cn.javass.spring.chapter2.helloworld.HelloImpl"/>
别名与Bean同样使用。通过该方法获取bean_name的全部别名。
beanFactory.getAliases("bean_name");
注:别名与标识符必须唯一。
< constructor-arg >
index : 位置
value : 常量值 | ref : 引用另一个Bean定义
使用有参数构造器进行定义,使用此中方式,可以使用< constructor-arg >标签指定构造器参数值,其中index表示位置,value表示常量值,也可以指定引用,指定引用使用ref来引用另一个Bean定义.
<!--使用默认构造参数-->
<bean name="bean1" class="cn.javass.spring.chapter2.HelloImpl2"/> <!--使用有参数构造参数-->
<bean name="bean2" class="cn.javass.spring.chapter2.HelloImpl2"> <!-- 指定构造器参数 -->
<constructor-arg index="0" value="Hello Spring!"/> </bean>
<property>
通过setting的依赖注入。
index : 位置
value : 常量值 | ref : 引用另一个Bean定义
<!-- 通过setter方式进行依赖注入 -->
<bean id="bean" class="cn.javass.spring.chapter3.HelloImpl4">
<property name="message" value="Hello World!"/>
<property name="index">
<value>1</value>
<!--
如果这样配置 ref等价
<idref local=""/>
-->
</property>
</bean>
注:Spring类型转换系统对于boolean类型进行了容错处理,除了可以使用“true/false”标准的Java值进行注入,还
能使用“yes/no”、“on/off”、“1/0”来代表“真/假”,所以大家在学习或工作中遇到这种类似问题不要觉得是人
家配置错了,而是Spring容错做的非常好。
注入集合、数组和字典
<list>配置list
<bean id="listBean" class="cn.javass.spring.chapter3.bean.ListTestBean"
<property name="values">
<list>
<value>1</value>
<value>2</value>
<value>3</value>
</list>
</property>
</bean>
**<set>**同上配置set
<value> 配置数组。
value-type : 数组的类型 和 merge 相同。
<map>
“key-type”和“value-type”分别指定“键”和“值”的数据类型。
- **<entry>**键值对
–<key> 键
–<value> 值
<props>
Properties注入:Spring能注入java.util.Properties类型数据,需要使用<props>标签来配置注入,键和值类型必
须是String,不能变,子标签<prop key=”键”>值</prop>来指定键值对
内部Bean
该内部Bean对其他外部Bean不可见,
<bean id="bean" class="cn.javass.spring.chapter3.bean.HelloApiDecorator">
<property name="helloApi">
<bean id="helloApi" class="cn.javass.spring.chapter2.helloworld.HelloImpl"/>
</property>
</bean>
p命名空间
xmlns:p="http://www.springframework.org/schema/p
<bean id="……" class="……" p:id=“value”/> :常量setter注入方式,其等价于<property name=“id” value=“value”/>;
<bean id="……" class="……" p:id-ref=“bean1”/> :引用setter注入方式,其等价于<property name=“id” ref=“bean1”/>
循环依赖时抛出
BeanCurrentlyInCreationException