怎么从xml中过去Java类_java类中从spring的ApplicationContext.xml中获取bean

1. 通常我们在java类中,如果想要获取applicationContext.xml中配置的bean,会采用下面方式:

importjavax.sql.DataSource;importorg.springframework.context.ApplicationContext;importorg.springframework.context.support.FileSystemXmlApplicationContext;public classSpringConfigTest

{public static void main(String[] args) throwsException

{

ApplicationContext ac= new FileSystemXmlApplicationContext("classpath:applicationContext.xml");

DataSource datasource= (DataSource) ac.getBean("dataSource");

}

}

这种方式确实可以从applicationContext.xml中获取到指定id的Bean,但是效率很低,每次去getBean时都重新加载了applicationContext.xml文件,在web开发中是不建议直接这样用的,可以采用下面的方法

2. Spring中提供了获取ApplicationContext对象的接口,在 org.springframework.context.ApplicationContextAware中我们只需实现 ApplicationContextAware接口的setApplicationContext方法,然后在Spring的配置文件 applicationContext.xml中 注册实现ApplicationContextAware接口的类的类,并用静态的 ApplicationContext变量把ApplicationContext保存下来,就可以了(并在web.xml中配置只要配置了spring监听器,那么在服务启动时读取配置文件并为applicationContext赋值,然后就可以随心所欲的使用静态的ApplicationContext了

步骤1:写一个类实现ApplicationContextAware,并实现setApplicationContext()方法.

importorg.springframework.beans.BeansException;importorg.springframework.context.ApplicationContext;importorg.springframework.context.ApplicationContextAware;public class SpringFactory implementsApplicationContextAware

{private staticApplicationContext context;/*** 实现setApplicationContext()*/

public voidsetApplicationContext(ApplicationContext context)throwsBeansException

{this.context =context;

}/*** 从applicationContext中获取指定id的bean

*@paramid要获取的springBean的id

*@return

*/

public staticObject getObject(String id) {

Object object= null;

object=context.getBean(id);returnobject;

}

}

步骤2:在spring的applicationContext.xml中配置该bean

步骤3:web.xml中要配置spring监听器(目的容器启动时就加载applicationContext.xml)

contextConfigLocation

classpath:applicationContext.xml

org.springframework.web.context.ContextLoaderListener

步骤 4. 现在开始就可以在项目中j使用SpringFactory类获取指定id的Bean了(必须服务器启动下,去测试,否则肯定是空指针异常)

public classDBUtil

{private staticDataSource dataSource;static{

dataSource= (DataSource) SpringFactory.getObject("dataSource");

}//获得连接

public static Connection getConnection() throwsSQLException

{returndataSource.getConnection();

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值