spring5(三):IOC操作Bean管理(基于xml方式)
IOC操作Bean管理(基于xml方式)
- 前言
-
- 一、基于 xml 方式创建对象
- 二、基于 xml 方式注入属性
-
- 1. 使用 set 方法进行属性注入
- 2. 使用有参数构造进行属性注入
- 3. p 名称空间注入简化操作(了解)
- 三、xml 注入其它类型属性
-
- 1. 字面量
- 2. 注入属性-外部 bean
- 3. 注入属性-内部 bean
- 4. 注入属性-级联赋值
- 四、xml 注入集合属性
-
- 1. 注入数组类型属性
- 2. 注入 List 集合类型属性
- 3. 注入 Map 集合类型属性
- 4. 在集合里面设置对象类型值
- 5. 把集合注入部分提取出来
- 五、bean作用域
- 六、bean 生命周期
- 七、xml 自动装配
- 八、外部属性文件
- 九、FactoryBean
前言
本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主!也许一个人独行,可以走的很快,但是一群人结伴而行,才能走的更远!让我们在成长的道路上互相学习,欢迎关注!
一、基于 xml 方式创建对象
⭕在
spring
配置文件中,使用bean
标签,标签里面添加对应属性,就可以实现对象创建
⭕在
bean
标签有很多属性,介绍常用的属性
id
属性:唯一标识class
属性:类全路径(包类路径)name
属性:作用与id
属性一致,区别是name
属性里面可以用特殊字符,但现在很少用name
属性了
⭕创建对象时候,默认也是执行无参数构造方法完成对象创建,如果在类里用有参构造器覆盖无参构造器,运行时则会报错。
二、基于 xml 方式注入属性
DI:依赖注入,就是注入属性
1. 使用 set 方法进行属性注入
① 创建类,定义属性和对应的 set 方法
//演示使用 set 方法进行注入属性
public class Person {private String name;private String food;public void setName(String name) {this.name = name;}public void setFood(String food) {this.food = food;}public void eat(){System.out.println(this.name+"吃"+this.food);}}
② 在 spring 配置文件配置对象创建,配置属性注入
<!--配置 Person 对象创建--><bean id="person_ir" class="com.ir.spring5.Person"><!--使用 property 完成属性注入name:类里面属性名称value:向属性注入的值--><property name="name" value="小老师ir"></property><property name="food" value="java"></property></bean>
property标签中的属性name是相应的类中的属性名,value是指要赋予属性的值
③ 测试代码:
@Test public void testEat(){ //1.加载spring配置文件 ApplicationContext context = new ClassPathXmlApplicationContext("person1.xml"); //2. 获取配置创建的对象 Person person = context.getBean("person_ir",Person.class); //3. 测试 System.out.println(person);//com.ir.spring5.Person@1b26f7b2 person.eat(); //[小老师ir]吃java }
2. 使用有参数构造进行属性注入
① 创建类,定义属性,创建属性对应有参数构造方法
package com.ir.spring5;public class Car {private String number;private String speed;public Car(String number, String speed) {this.number = number;this.speed = speed;}public void run(){System.out.println(number+"::"+speed);}
}
② 在 spring 配置文件中进行配置
<!--配置 Car 对象创建--><bean id="car_ir" class="com.ir.spring5.Car"><!--有参数构造注入属性--><!--方式1:通过name属性来确定类中的属性名--><constructor-arg name="number" value="01"></constructor-arg><constructor-arg name="speed" value="200"></constructor-arg><!--方式2:通过索引来确定属性名-->
<!-- <constructor-arg index="0" value="01"></constructor-arg>-->
<!-- <constructor-arg index="1" value="200"></constructor-arg>--></bean>
测试:
@Test public void testCar(){ //1.加载配置文件 ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml"); //2.获取配置文件创建的对象 Car car = context.getBean("car_ir",Car.class); //3.测试 System.out.println(car);//com.ir.spring5.Car@a74868d car.run();//01::200 }
3. p 名称空间注入简化操作(了解)
使用 p 名称空间注入,可以简化基于 xml 配置方式
① 添加 p 名称空间在配置文件中
② 进行属性注入,在 bean 标签里面进行操作
<bean id="person_ir" class="com.ir.spring5.Person" p:name="小老师ir" p:food="c++">
</bean>
三、xml 注入其它类型属性
1. 字面量
⭕ null 值
<bean id="person_ir" class="com.ir.spring5.Person"><property name="name" ><null/></property><property name="food" value="java"></property></bean>
@Test
public void testEat(){ ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml"); Person person = context.getBean("person_ir",Person.class); System.out.println(person);//com.ir.spring5.Person@1b26f7b2 person.eat(); //[null]吃java
⭕ 属性值包含特殊符号
● 方法一:把<>进行转义
<
>
<bean id="person_ir" class="com.ir.spring5.Person"><property name="name" value="<小老师ir>"></property><property name="food" value="java"></property></bean>
@Test
public void testEat(){ ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml"); Person person = context.getBean("person_ir",Person.class); System.out.println(person);//com.ir.spring5.Person@a74868d person.eat(); //<小老师ir>吃java
● 方法二:把带特殊符号内容写到 CDATA
<bean id="person_ir" class="com.ir.spring5.Person"><property name="name" ><value><![CDATA[<<小老师ir>>]]></value></property><property name="food" value="java"></property></bean>
@Test
public void testEat(){ //1.加载spring配置文件 ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");//2. 获取配置创建的对象 Person person = context.getBean("person_ir",Person.class); //3. 测试 System.out.println(person);//com.ir.spring5.Person@a74868d person.eat(); //[<<小老师ir>>]吃java
2. 注入属性-外部 bean
演示步骤:
① 创建两个类 service 类和 dao 类
② 在 service 调用 dao 里面的方法
UserDao
package Dao;/*** @author shkstart* @create 2022-05-07 23:08*/
public interface UserDao {public void update();
}
UserService
package Service;import Dao.UserDao;/*** @author shkstart* @create 2022-05-07 23:08*/
public class UserService {//创建 UserDao 类型属性,生成 set 方法private UserDao userDao;public void setUserDao(UserDao userDao) {this.userDao = userDao;}public void add() {System.out.println("service add...............");userDao.update();}
}
UserDaoImpl
package Dao;/*** @author shkstart* @create 2022-05-07 23:08*/
public class UserDaoImpl implements UserDao{@Overridepublic void update() {System.out.println("dao update...........");}
}
③ 在 spring 配置文件中进行配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:util="http://www.springframework.org/schema/util"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/util https://www.springframework.org/schema/util/spring-util.xsd"><!--创建 UserService 对象--><bean id="userservice" class="Service.UserService"><!--注入 userDao 对象name 属性:类里面属性名称ref 属性:创建 userDao 对象 bean 标签 id 值--><property name="userDao" ref="userdaoimpl"></property></bean><!--创建 UserDaoImpl 对象--><bean id="userdaoimpl" class="Dao.UserDaoImpl"></bean></beans>
测试:
@Testpublic void testBean(){ApplicationContext context1 = new ClassPathXmlApplicationContext("bean2.xml");UserService userService = (UserService)context1.getBean("userservice");System.out.println(userService);//Service.UserService@eafc191userService.add();
// service add...............
// dao update...........}
3. 注入属性-内部 bean
① 一对多关系:部门和员工,一个部门有多个员工,一个员工属于一个部门,部门是一,员工是多
② 在实体类之间表示一对多关系,员工表示所属部门,使用对象类型属性进行表示
部门类
package Bean;
public class Dept {private String dname;public void setDname(String dname) {this.dname = dname;}@Overridepublic String toString() {return "Dept{" +"dname='" + dname + '\\'' +'}';}
}
员工类
package Bean;public class Emp {private String ename;private String gender;//员工属于某一个部门,使用对象形式表示private Dept dept;public void setDept(Dept dept) {this.dept = dept;}public void setEname(String ename) {this.ename = ename;}public void setGender(String gender) {this.gender = gender;}public void add() {System.out.println(ename+"::"+gender+"::"+dept);}
}
③ 在 spring 配置文件中进行配置
<!--内部bean--><bean id="emp" class="Bean.Emp"><!--设置两个属性--><property name="ename" value="小老师ir"></property><property name="gender" value="女"></property><!--设置对象类型属性--><property name="dept"><bean id="dept" class="Bean.Dept"><property name="dname" value="安保部"></property></bean></property></bean>
测试
@Testpublic void testEmp(){ApplicationContext context = new ClassPathXmlApplicationContext("bean3.xml");Emp emp = (Emp)context.getBean("emp");System.out.println(emp);//Bean.Emp@69b0fd6femp.add();//小老师ir::女::Dept{dname='安保部'}}
4. 注入属性-级联赋值
方式一:
在 spring 配置文件
bean4.xml
中进行配置
<!--级联赋值--><bean id="emp" class="Bean.Emp"><!--设置两个普通属性--><property name="ename" value="小老师ir"></property><property name="gender" value="女"></property><!--级联赋值--><property name="dept" ref="dept"></property></bean><bean id="dept" class="Bean.Dept"><property name="dname" value="技术部"></property></bean>
测试:
@Testpublic void testEmp2(){ApplicationContext context = new ClassPathXmlApplicationContext("bean4.xml");Emp emp = (Emp)context.getBean("emp");System.out.println(emp);//Bean.Emp@462d5aeeemp.add();//小老师ir::女::Dept{dname='技术部'}}
方式二:员工属于某一个部门,使用对象形式表示
<!--级联赋值--><bean id="emp" class="Bean.Emp"><!--设置两个普通属性--><property name="ename" value="小老师ir"></property><property name="gender" value="女"></property><!--级联赋值--><property name="dept" ref="dept"></property><property name="dept.dname" value="技术部"></property></bean><bean id="dept" class="Bean.Dept"></bean>
测试:
@Testpublic void testEmp3(){ApplicationContext context = new ClassPathXmlApplicationContext("bean4.xml");Emp emp = (Emp)context.getBean("emp");System.out.println(emp);//Bean.Emp@757942a1emp.add();//小老师ir::女::Dept{dname='技术部'}}
注意:此种方法中,
Emp
类中必须有getDept( )
方法
四、xml 注入集合属性
1. 注入数组类型属性
2. 注入 List 集合类型属性
3. 注入 Map 集合类型属性
步骤:
① 创建类,定义数组、list、map、set 类型属性,生成对应 set 方法
Stu类
public class Stu {//1 数组类型属性private String[] courses;//2 list集合类型属性private List<String> list;//3 map集合类型属性private Map<String,String> maps;//4 set集合类型属性private Set<String> sets;public void setSets(Set<String> sets) {this.sets = sets;}public void setCourses(String[] courses) {this.courses = courses;}public void setList(List<String> list) {this.list = list;}public void setMaps(Map<String, String> maps) {this.maps = maps;}@Overridepublic String toString() {return "Stu{" +"courses=" + Arrays.toString(courses) +", list=" + list +", maps=" + maps +", sets=" + sets + '}';}
}
② 在 spring 配置文件进行配置
<bean id="student" class="collectiontest.Stu"> <!--注入数组属性--><property name="courses"><array ><value>Java</value><value>C++</value></array></property><!--注入list属性--><property name="list"><list><value>Python</value><value>Go</value></list></property><!--注入map属性--><property name="maps"><map><entry key="小老师ir" value="Java"></entry><entry key="小老师ir" value="C++"></entry></map></property><!--注入set属性--><property name="sets"><set><value>喜羊羊</value><value>美羊羊</value></set></property></bean>
测试:
@Testpublic void test(){ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");Stu student = context.getBean("student",Stu.class);System.out.println(student);//Stu{courses=[Java, C++], list=[Python, Go], maps={小老师ir=C++}, sets=[喜羊羊, 美羊羊]}}
4. 在集合里面设置对象类型值
Stu类
public class Stu {//1 数组类型属性private String[] courses;//2 list集合类型属性private List<String> list;//3 map集合类型属性private Map<String,String> maps;//4 set集合类型属性private Set<String> sets;//学生所学多门课程private List<Course> courseList;public void setCourseList(List<Course> courseList) {this.courseList = courseList;}public void setSets(Set<String> sets) {this.sets = sets;}public void setCourses(String[] courses) {this.courses = courses;}public void setList(List<String> list) {this.list = list;}public void setMaps(Map<String, String> maps) {this.maps = maps;}@Overridepublic String toString() {return "Stu{" +"courses=" + Arrays.toString(courses) +", list=" + list +", maps=" + maps +", sets=" + sets +", courseList=" + courseList +'}';}
}
Course类
//课程类
public class Course {private String cname; //课程名称public void setCname(String cname) {this.cname = cname;}@Overridepublic String toString() {return "Course{" +"cname='" + cname + '\\'' +'}';}
}
在 spring 配置文件进行配置
<!--创建多个 course 对象--><bean id="course1" class="collectiontest.Course"><property name="cname" value="英语课"></property></bean><bean id="course2" class="collectiontest.Course"><property name="cname" value="语文课"></property></bean><bean id="course3" class="collectiontest.Course"><property name="cname" value="数学课"></property></bean><!--创建Stu对象--><bean id="student1" class="collectiontest.Stu"><!--注入 list 集合类型,值是对象--><property name="courseList"><list><ref bean="course1"></ref><ref bean="course2"></ref><ref bean="course3"></ref></list></property></bean>
测试
@Testpublic void test(){ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");Stu student = context.getBean("student1",Stu.class);System.out.println(student);//Stu{courses=null, list=null, maps=null, sets=null, courseList=[Course{cname='英语课'}, Course{cname='语文课'}, Course{cname='数学课'}]}}
5. 把集合注入部分提取出来
Book类·
public class Book {private List<String> list;public void setList(List<String> list) {this.list = list;}@Overridepublic String toString() {return "Book{" +"list=" + list +'}';}
}
步骤:
① 在 spring 配置文件中引入名称空间 util
② 在 spring 配置文件进行配置,使用 util 标签完成 list 集合注入提取
<!--1 提取list集合类型属性注入--><util:list id="bookList"><value>java</value><value>c++</value><value>python</value></util:list><!--2 提取list集合类型属性注入使用--><bean id="book" class="collectiontest.Book" scope="prototype"><property name="list" ref="bookList"></property></bean>
测试
@Testpublic void test(){ApplicationContext context = new ClassPathXmlApplicationContext("bean2.xml");Book book= context.getBean("book", Book.class);System.out.println(book);//Book{list=[java, c++, python]}}
五、bean作用域
⭕ 在 Spring 里面,设置创建 bean 实例是单实例还是多实例 ?
⭕在 Spring 里面,默认情况下,bean 是单实例对象
Book类
public class Book {private List<String> list;public void setList(List<String> list) {this.list = list;}
}
在 spring 配置文件进行配置
<!--1 提取list集合类型属性注入--><util:list id="bookList"><value>java</value><value>c++</value><value>python</value></util:list><!--2 提取list集合类型属性注入使用--><bean id="book" class="collectiontest.Book" ><property name="list" ref="bookList"></property></bean>
测试:
@Testpublic void test(){ApplicationContext context = new ClassPathXmlApplicationContext("bean2.xml");Book book1= context.getBean("book", Book.class);Book book2= context.getBean("book", Book.class);System.out.println(book1);//collectiontest.Book@27d415d9System.out.println(book2);//collectiontest.Book@27d415d9}
由以上测试输出结果可知,创建的两个book对象地址相同,即为其实是同一个对象
⭕如何设置单实例还是多实例
● 在 spring 配置文件 bean 标签里面有属性(scope)用于设置单实例还是多实例
● scope 属性值,其中有两个常见的词
- 第一个值,默认值,singleton,表示是单实例对象
- 第二个值prototype,表示是多实例对象 Book类与如上相同
在 spring 配置文件进行配置
<!--1 提取list集合类型属性注入--><util:list id="bookList"><value>java</value><value>c++</value><value>python</value></util:list><!--2 提取list集合类型属性注入使用--><bean id="book" class="collectiontest.Book" scope="prototype"><property name="list" ref="bookList"></property>y</bean>
测试:
@Testpublic void test(){ApplicationContext context = new ClassPathXmlApplicationContext("bean2.xml");Book book1= context.getBean("book", Book.class);Book book2= context.getBean("book", Book.class);System.out.println(book1);//collectiontest.Book@27d415d9System.out.println(book2);//collectiontest.Book@5c18298f}
由以上测试输出结果可知,创建的两个book对象地址不相同,即为是两个对象
⭕ singleton 和 prototype 区别
● singleton 单实例,prototype 多实例
● 设置 scope 值是 singleton 时候,加载 spring 配置文件时候就会创建单实例对象
● 设置 scope 值是 prototype 时候,不是在加载 spring 配置文件时候创建 对象,而是在调用getBean 方法时候创建多实例对象
六、bean 生命周期
⭕ 生命周期:从对象创建到对象销毁的过程
⭕ bean 生命周期
(1)通过构造器创建 bean 实例(无参数构造)
(2)为 bean 的属性设置值和对其他 bean 引用(调用set 方法)
(3)调用 bean 的初始化的方法(需要进行配置初始化的方法)
(4)bean 可以使用了(对象获取到了)
(5)当容器关闭时候,调用 bean 的销毁的方法(需要进行配置销毁的方法)
⭕ 演示 bean 生命周期
Order类
public class Order {private String name;public Order() {System.out.println("第一步:执行无参构造器创建对象");}public void setName(String name) {this.name = name;System.out.println("第二步:调用set()方法设置属性值");}public void initMethod(){System.out.println("第三步:执行初始化方法");}public void destroyMethod(){System.out.println("第五步:执行销毁的方法");}}
在 spring 配置文件进行配置
<bean id="order" class="collectiontest.Order" init-method="initMethod" destroy-method="destroyMethod"><property name="name" value="电脑订单"></property>
</bean>
测试:
@Testpublic void test(){ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("bean4.xml");Order order= context.getBean("order", Order.class);System.out.println("第四步:获取创建 bean 实例对象");System.out.println(order);context.close();
// 第一步:执行无参构造器创建对象
// 第二步:调用set()方法设置属性值
// 第三步:执行初始化方法
// 第四步:获取创建 bean 实例对象
// collectiontest.Order@4a87761d
// 第五步:执行销毁的方法}
⭕ bean 的后置处理器,bean 生命周期有七步
(1)通过构造器创建 bean 实例(无参数构造)
(2)为 bean 的属性设置值和对其他 bean 引用(调用 set 方法)
(3)把bean 实例传递 bean 后置处理器的方法 postProcessBeforeInitialization
(4)调用 bean 的初始化的方法(需要进行配置初始化的方法)
(5)把 bean 实例传递 bean 后置处理器的方法postProcessAfterInitialization
(6)bean 可以使用了(对象获取到了)
(7)当容器关闭时候,调用bean 的销毁的方法(需要进行配置销毁的方法)
⭕ 演示添加后置处理器效果
(1)创建类,实现接口 BeanPostProcessor,创建后置处理器
public class MyBeanPost implements BeanPostProcessor {@Overridepublic Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {System.out.println("在初始化之前执行的方法");return bean;}@Overridepublic Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {System.out.println("在初始化之后执行的方法");return bean;}
}
在 spring 配置文件进行配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"><!--配置order对象--><bean id="order" class="bean.Order" init-method="initMethod" destroy-method="destroyMethod"><property name="name" value="电脑订单"></property></bean><!--配置后置处理器--><bean id="mybeanpost" class="bean.MyBeanPost"></bean>
</beans>
测试:
@Testpublic void test(){ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("bean4.xml");Order order= context.getBean("order", Order.class);System.out.println("第四步:获取对象");System.out.println(order);context.close();
// 第一步:执行无参构造器创建对象
// 第二步:调用set()方法设置属性值
// 在初始化之前执行的方法
// 第三步:执行初始化方法
// 在初始化之后执行的方法
// 第四步:获取对象
// bean.Order@37374a5e
// 第五步:执行销毁的方法}
七、xml 自动装配
⭕ 什么是自动装配?
根据指定装配规则(属性名称或者属性类型),Spring 自动将匹配的属性值进行注入
① bean 标签属性 autowire,配置自动装配
② autowire 属性常用两个值:
- byName:根据属性名称注入 ,注入值 bean 的 id 值和类属性名称一样
- byType :根据属性类型注入
⭕演示自动装配过程
● 根据属性名称自动注入
Dept类
public class Dept {private String name;public void setName(String name) {this.name = name;}@Overridepublic String toString() {return "Dept{" +"name='" + name + '\\'' +'}';}
}
Emp类
public class Emp {private Dept dept;public void setDept(Dept dept) {this.dept = dept;}@Overridepublic String toString() {return "Emp{" +"dept=" + dept +'}';}
}
在 spring 配置文件进行配置
<!--创建emp对象--><!--使用自动装配方式注入属性:通过属性名的方式--><bean id="emp" class="bean.Emp" autowire="byName"><!--使用手动方式注入属性-->
<!-- <property name="dept" ref="dept"></property>--></bean><!--创建dept对象--><bean id="dept" class="bean.Dept"><property name="name" value="技术部"></property></bean>
测试:
@Testpublic void test() {ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("bean5.xml");Emp emp = context.getBean("emp", Emp.class);System.out.println(emp);//Emp{dept=Dept{name='技术部'}}}
● 根据属性类型自动注入
<!--创建emp对象--><!--使用自动装配方式注入属性:通过属性类型的方式--><bean id="emp" class="bean.Emp" autowire="byType"><!--使用手动方式注入属性-->
<!-- <property name="dept" ref="dept"></property>--></bean><!--创建dept对象--><bean id="dept" class="bean.Dept"><property name="name" value="技术部"></property></bean>
测试:
@Testpublic void test() {ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("bean5.xml");Emp emp = context.getBean("emp", Emp.class);System.out.println(emp);//Emp{dept=Dept{name='技术部'}}}
注意:通过属性类型的方式自动装配时,同一类型不能有多个bean对象,否则会报错
八、外部属性文件
⭕ 直接配置数据库信息
① 引入德鲁伊连接池依赖 jar 包
② 配置德鲁伊连接池
<!--创建数据库连接池对象--><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"><!--直接对连接池进行属性配置--><property name="driverClassName" value="com.mysql.jdbc.Driver"></property><property name="url" value="jdbc:mysql://localhost:3306/userDb"></property><property name="username" value="root"></property><property name="password" value="root"></property></bean>
⭕ 引入外部属性文件配置数据库连接池
(1)创建外部属性文件,properties 格式文件,写数据库信息
jdbc.properties
prop.driverClass=com.mysql.jdbc.Driver
prop.url=jdbc:mysql://localhost:3306/userDb
prop.userName=root
prop.password=root
(2)把外部 properties 属性文件引入到 spring 配置文件中
① 引入 context 名称空间
② 在 spring 配置文件使用标签引入外部属性文件
<!--引入外部属性文件--><context:property-placeholder location="classpath:jdbc.properties"/><!--创建数据库连接池对象--><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"><!--对连接池进行属性配置--><property name="driverClassName" value="com.mysql.jdbc.Driver"></property><property name="url" value="jdbc:mysql://localhost:3306/userDb"></property><property name="username" value="root"></property><property name="password" value="root"></property></bean>
九、FactoryBean
Spring 有两种类型 bean,一种普通 bean,另外一种工厂 bean(FactoryBean)
- 普通 bean:在配置文件中定义 bean 类型就是返回类型
- 工厂 bean:在配置文件定义 bean 类型可以和返回类型不一样
步骤:
① 创建类,让这个类作为工厂 bean,实现接口 FactoryBean
② 实现口里面的方法,在实现的方法中定义返回的bean 类型
Course类
public class Course {private String cname; //课程名称public void setCname(String cname) {this.cname = cname;}public String getCname(){return this.cname;}@Overridepublic String toString() {return "Course{" +"cname='" + cname + '\\'' +'}';}
}
public class MyBean implements FactoryBean<Course> {@Overridepublic Course getObject() throws Exception {Course course = new Course();course.setCname("Java");return course;}@Overridepublic Class<?> getObjectType() {return null;}
}
③ 在 spring 配置文件进行配置
<!--创建MyBean对象--><bean id="mybean" class="factorybean.MyBean"></bean>
测试:
@Testpublic void test(){ApplicationContext context = new ClassPathXmlApplicationContext("bean3.xml");Course course= context.getBean("mybean", Course.class);System.out.println(course.getCname());//Java}