Bean XML 配置(1)- 通过XML配置加载Bean

1. 定义Bean

在xml配置文件中(如”beans.xml”),添加Bean定义:

<!-- 定义一个Bean -->
<bean id="..." class="...">
   <!-- bean 配置 -->
</bean>

<!-- App bean -->
<bean id="app" class="App" lazy-init="true"></bean>

可以给Bean设置一些属性,此处用到的属性说明:

  • id: bean的唯一标识符
  • class: 指定bean的Java类名称
  • lazy-init: 懒加载,让Spring容器在Bean首次用到时创建Bean实例,而不是在应用一启动就创建

2. 创建Spring容器

Spring容器负责加载bean配置文件、创建bean。

前面教程提到过有2种容器:

  • ApplicationContext
  • BeanFactory

ApplicationContext基于BeanFactory,比BeanFactory功能更强,更常用。

BeanFactory 容器

BeanFactory容器是简单的IOC容器,只提供基本的依赖注入支持。BeanFactory本身是一个Java接口,最常见的实现是XmlBeanFactory类。通常不直接使用BeanFactory容器,而是用ApplicationContext 容器。

ApplicationContext 容器

ApplicationContext容器是更高级更常用的容器,继承并扩展了BeanFactory的功能。同样ApplicationContext本身是一个Java接口,常用的实现类是:

  • FileSystemXmlApplicationContext: 通过文件路径加载bean的xml配置文件
  • ClassPathXmlApplicationContext: 通过类路径加载bean的xml配置文件
  • WebXmlApplicationContext: 通过web网址加载bean的xml配置文件

代码示例:


import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class Test { public static void main(String[] args) { // ApplicationContext容器加载beans.xml ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml"); } }

3. 通过Spring容器获取bean

通过Spring容器可以访问它所管理的任意Bean,可使用getBean()方法返回Bean实例。

示例:

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Test {
    public static void main(String[] args) {

        ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");

        // 获取Bean实例
        App app = context.getBean("app", App.class);
        // App app = (App) context.getBean("app");
    }
}

4. 关闭容器

最后应用结束时需要关闭容器,释放资源,容器中的所有bean也将被销毁。


context.close(); // 如果当前context类没有close方法,需类型转换为有close方法的类,如下所示 // ((ClassPathXmlApplicationContext) context).close(); // ((ConfigurableApplicationContext) context).close();


浙ICP备17015664号 浙公网安备 33011002012336号 联系我们 网站地图  
@2019 qikegu.com 版权所有,禁止转载