spring 项目中获取bean 的方法


1、Web工程:
     1)ContextLoaderListener.getCurrentWebApplicationContext ().getBean ("beanName"); 

     2)使用servletContext来获取ApplicationContext
          ApplicationContext ac1 = WebApplicationContextUtils.getRequiredWebApplicationContext(ServletContext sc); 
          ApplicationContext ac2 = WebApplicationContextUtils.getWebApplicationContext(ServletContext sc); 

          这两中方式的区别在于前者在获取失败时会抛出异常,而后者在获取失败时会返回null

     3)自己写一个listener实现ServletContextListener接口
          web.xml中配置好listener
          <listener> 
        <listener-class>com.ibatis.jpetstore.util.SpringInit</listener-class> 
</listener>

listener实现类

public class SpringInit implements ServletContextListener { 
    

    private static WebApplicationContext springContext; 
    
    public SpringInit() { 
        super(); 
    } 
    
    public void contextInitialized(ServletContextEvent event) { 
        springContext = WebApplicationContextUtils.getWebApplicationContext(event.getServletContext()); 
    } 
    

    public void contextDestroyed(ServletContextEvent event) { 
    } 
    
    public static ApplicationContext getApplicationContext() { 
        return springContext; 
    } 

    


2、普通Java工程:
     1)写一个类实现ApplicationContextAware接口
       /**
*
*/
public class ApplicationContextUtil implements ApplicationContextAware
{
    private static ApplicationContext context;//声明一个静态变量保存
    @SuppressWarnings ("static-access")
    @Override
    public void setApplicationContext (ApplicationContext context) throws BeansException
    {
        this.context = context;
       
    }
   
    public static ApplicationContext getContext(){
        return context;
    }
}
2)在Spring的配置文件中加入:<bean id="applicationContextUtil" class="net.carefx.platform.mdm.server.core.utils.ApplicationContextUtil" />

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对你的问题,我来简单介绍一下如何在Spring项目获取Oracle数据。 1. 首先,需要在pom.xml添加Oracle数据库驱动的依赖。例如: ```xml <dependency> <groupId>com.oracle.database.jdbc</groupId> <artifactId>ojdbc8</artifactId> <version>19.3.0.0</version> </dependency> ``` 2. 在Spring配置文件,配置数据源。例如: ```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" /> <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl" /> <property name="username" value="username" /> <property name="password" value="password" /> </bean> ``` 其,url的localhost需要修改为实际的Oracle服务器地址,1521为Oracle默认的端口号,orcl为Oracle的服务名。 3. 在DAO层,使用JdbcTemplate来执行SQL语句。例如: ```java public class UserDaoImpl implements UserDao { private JdbcTemplate jdbcTemplate; public void setDataSource(DataSource dataSource) { this.jdbcTemplate = new JdbcTemplate(dataSource); } public List<User> findAll() { String sql = "SELECT * FROM USER"; List<User> userList = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); return userList; } } ``` 在上述代码,使用了JdbcTemplate的query方法来执行SQL语句,并将查询结果映射为User类的对象。 以上是在Spring项目获取Oracle数据的基本步骤,需要根据实际情况进行具体的配置和编码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值