id
bean标签的唯一标识符,在 spring 容器中,只能存在唯一的 id 不能重复, 否则报错
。
name
- bean 标签的名称标识符, 效果等同于id属性;
- 并且
id
与name
不能重复,name
与name
也不能重复; - 同一个bean标签可以同时设置多个name值,以
空格
、逗号
、分号隔开
。
<bean id="dataSource" name='ds,ds2' class="com.alibaba.druid.pool.DruidDataSource"></bean>
DruidDataSource dataSource = ac.getBean("dataSource", DruidDataSource.class);
DruidDataSource dataSource = ac.getBean("ds2", DruidDataSource.class);
DruidDataSource dataSource = ac.getBean("ds", DruidDataSource.class);
class
bean 加载类的全类名(全限定类名)
init-method
初始化执行方法:
- 我们的普通javaBean对象是没有初始化执行的方法的(super()是实例化执行的)
- 使用方法:
- 在bean对象中预先创建一个可执行public方法,然后给 init-method 赋值方法名,bean对象在初始化时就会调用
举例
- 在bean对象中预先创建一个可执行public方法,然后给 init-method 赋值方法名,bean对象在初始化时就会调用
// 学生对象
public class Student {
private Integer id;
private String name;
private String className;
public void initStudent() {
System.out.println("初始化学生对象");
}
// 省略了 getter & setter & super & 有参 构造方法
}
// spring bean 对象的配置文件 (springxml/beanConfig.xml)
<bean id="student" class="com.cc.spring.bean.Student" init-method="initStudent">
<property name="id" value='1001'></property>
<property name="name" value="三好学生"></property>
<property name="className" value="三年级(2)班"></property>
</bean>
// main 方法
public static void main(String[] args) {
ApplicationContext ctx = new ClassPathXmlApplicationContext("springxml/beanConfig.xml");
}
注意:在执行main方法时,只加载了springBean的配置文件,并没有加载、调用studentBean,但是执行了 initStudent()
方法。
destory-method
bean 对象销毁时调用的方法;
使用方法与 init-method 类似;
一般在该方法中可以释放资源。
scope
- bean 对象的作用域(范围):
- singleton:(单例实现)表示整个IOC容器共享一个Bean,也就是说每次说每次通过getBean获取的bean都是同一个。
- prototype:(多例实现)每次对该bean请求(将其注入到另一个bean中,或者以程序的方式调用容器的getBean()方法)时都会创建一个新的bean实例。
- request:每次HTTP请求将会生成各自的bean实例
- session:每次会话请求对应一个bean实例
factory-method
指定一个静态的工厂方法创建bean对象:
- 如上文,已经有了个学生类:
- 创建一个学生工厂类:
public static class StudentFactory {
public Student studentFactory() {
return new Student();
}
}
- 配置 spring.xml配置文件
注意:这样配置的factory必须是 static 修饰
<bean id="stuFromFactory" class="com.cc.spring.bean.StudentFactory" factory-method="studentFactory" ></bean>
- 执行main方法:
public static void main(String[] args) {
ApplicationContext ctx = new ClassPathXmlApplicationContext("springxml/beanConfig.xml");
System.out.println(ctx.getBean("stuFromFactory"));
}
factory-bean
该属性一般与 factory-method 属性连用:
- 如上文,已经有了个学生类:
- 创建一个学生工厂类:
public class StudentFactory {
public Student studentFactory() {
return new Student();
}
}
- 配置 spring.xml配置文件注意:这样配置的factory不能是 static 修饰
<!-- 绑定 学生工厂 类对象 -->
<bean id="studentFactoryBean" class="com.cc.spring.bean.StudentFactory" ></bean>
<!-- 绑定 学生工厂bean的id(factory-bean), 使用factory-method 调用方法 -->
<bean id="studentFromFactory" factory-bean="studentFactoryBean" factory-method="studentFactory"></bean>
- 执行main方法:
public static void main(String[] args) {
ApplicationContext ctx = new ClassPathXmlApplicationContext("springxml/beanConfig.xml");
System.out.println(ctx.getBean("studentFromFactory"));
}
autowire
自动注入:(不便于控制,一般不用)
- no : 默认值,不进行自动装配
- byName : 根据属性名自动装配。此选项将检查容器并根据名字查找与属性完全一致的bean,并将其与属性自动装配
- byType : 如果容器中存在一个与指定属性类型相同的bean,那么将与该属性自动装配;如果存在多个该类型bean,那么抛出异常,并指出不能使用byType方式进行自动装配;如果没有找到相匹配的bean,则什么事都不发生,也可以通过设置dependency-check=”objects” 让Spring抛出异常。
- constructor:与byType方式类似,不同之处在于它应用于构造器参数。如果容器中没有找到与构造器参数类型一致的bean, 那么抛出异常
- autodetect : 通过bean类的内省机制(introspection)来决定是使用constructor还是byType方式进行自动装配。如果发现默认的构造器,那么将使用byType方式,否则采用 constructor。
- default:由上级标签的default-autowire属性确定。